diff --git a/resources/desktop/com.github.rssguard.appdata.xml b/resources/desktop/com.github.rssguard.appdata.xml
index 401cdf215..c4a4542df 100644
--- a/resources/desktop/com.github.rssguard.appdata.xml
+++ b/resources/desktop/com.github.rssguard.appdata.xml
@@ -26,7 +26,7 @@
https://github.com/sponsors/martinrotter
-
+
none
diff --git a/resources/rssguard.qrc b/resources/rssguard.qrc
index af4d7f9a0..d3e174478 100644
--- a/resources/rssguard.qrc
+++ b/resources/rssguard.qrc
@@ -75,6 +75,7 @@
skins/vergilius/html_enclosure_image.html
skins/vergilius/html_single_message.html
skins/vergilius/html_wrapper.html
+ skins/vergilius/html_style.css
skins/vergilius/metadata.xml
skins/vergilius/theme.css
diff --git a/resources/skins/plain/README b/resources/skins/plain/README
index b6306f8cf..f0fea7623 100644
--- a/resources/skins/plain/README
+++ b/resources/skins/plain/README
@@ -6,6 +6,7 @@ Here is overview of all placeholders used throughtout the skin:
%data% - is replaced by current absolute path to user data folder.
html_wrapper.html:
+ %style% - Skin-wide CSS, will be replaced by custom CSS if skin provides it in file "style.css".
%1 - Title of the article.
%2 - Body of the preview which is composed from:
- single html_single_message.html (single article preview),
diff --git a/resources/skins/vergilius/html_style.css b/resources/skins/vergilius/html_style.css
new file mode 100755
index 000000000..82f85d007
--- /dev/null
+++ b/resources/skins/vergilius/html_style.css
@@ -0,0 +1,2052 @@
+:root {
+ --fore-color: #111;
+ --secondary-fore-color: #444;
+ --back-color: #f8f8f8;
+ --secondary-back-color: #f0f0f0;
+ --blockquote-color: #f57c00;
+ --pre-color: #1565c0;
+ --border-color: #aaa;
+ --secondary-border-color: #ddd;
+ --heading-ratio: 1.19;
+ --universal-margin: .25rem;
+ --universal-padding: .25rem;
+ --universal-border-radius: .125rem;
+ --a-link-color: #0277bd;
+ --a-visited-color: #01579b
+}
+
+html {
+ font-size: 16px
+}
+
+a, b, del, em, i, ins, q, span, strong, u {
+ font-size: 1em
+}
+
+html, * {
+ line-height: 1.5;
+ -webkit-text-size-adjust: 100%
+}
+
+* {
+ font-size: 1rem
+}
+
+body {
+ margin: 0;
+ color: var(--fore-color);
+ background: var(--back-color)
+}
+
+details {
+ display: block
+}
+
+summary {
+ display: list-item
+}
+
+abbr[title] {
+ border-bottom: none;
+ text-decoration: underline dotted
+}
+
+input {
+ overflow: visible
+}
+
+img {
+ max-width: 100%;
+ height: auto
+}
+
+h1, h2, h3, h4, h5, h6 {
+ line-height: 1.2;
+ margin: calc(1.5 * var(--universal-margin)) var(--universal-margin);
+ font-weight: 500
+}
+
+h1 small, h2 small, h3 small, h4 small, h5 small, h6 small {
+ color: var(--secondary-fore-color);
+ display: block;
+ margin-top: -.25rem
+}
+
+h1 {
+ font-size: calc(1rem * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio))
+}
+
+h2 {
+ font-size: calc(1rem * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio))
+}
+
+h3 {
+ font-size: calc(1rem * var(--heading-ratio) * var(--heading-ratio))
+}
+
+h4 {
+ font-size: calc(1rem * var(--heading-ratio))
+}
+
+h5 {
+ font-size: 1rem
+}
+
+h6 {
+ font-size: calc(1rem / var(--heading-ratio))
+}
+
+p {
+ margin: var(--universal-margin)
+}
+
+ol, ul {
+ margin: var(--universal-margin);
+ padding-left: calc(2 * var(--universal-margin))
+}
+
+b, strong {
+ font-weight: 700
+}
+
+hr {
+ box-sizing: content-box;
+ border: 0;
+ line-height: 1.25em;
+ margin: var(--universal-margin);
+ height: .0625rem;
+ background: linear-gradient(to right, transparent, var(--border-color) 20%, var(--border-color) 80%, transparent)
+}
+
+blockquote {
+ display: block;
+ position: relative;
+ font-style: italic;
+ color: var(--secondary-fore-color);
+ margin: var(--universal-margin);
+ padding: calc(3 * var(--universal-padding));
+ border: .0625rem solid var(--secondary-border-color);
+ border-left: .375rem solid var(--blockquote-color);
+ border-radius: 0 var(--universal-border-radius) var(--universal-border-radius) 0
+}
+
+blockquote:before {
+ position: absolute;
+ top: calc(0rem - var(--universal-padding));
+ left: 0;
+ font-size: 3rem;
+ font-weight: 700;
+ content: "\201c";
+ color: var(--blockquote-color)
+}
+
+blockquote[cite]:after {
+ font-style: normal;
+ font-size: .75em;
+ font-weight: 700;
+ content: "\a— " attr(cite);
+ white-space: pre
+}
+
+code, kbd, pre, samp {
+ font-size: .85em
+}
+
+code {
+ background: var(--secondary-back-color);
+ border-radius: var(--universal-border-radius);
+ padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2)
+}
+
+kbd {
+ background: var(--fore-color);
+ color: var(--back-color);
+ border-radius: var(--universal-border-radius);
+ padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2)
+}
+
+pre {
+ overflow: auto;
+ background: var(--secondary-back-color);
+ padding: calc(1.5 * var(--universal-padding));
+ margin: var(--universal-margin);
+ border: .0625rem solid var(--secondary-border-color);
+ border-left: .25rem solid var(--pre-color);
+ border-radius: 0 var(--universal-border-radius) var(--universal-border-radius) 0
+}
+
+sup, sub, code, kbd {
+ line-height: 0;
+ position: relative;
+ vertical-align: baseline
+}
+
+small, sup, sub, figcaption {
+ font-size: .75em
+}
+
+sup {
+ top: -.5em
+}
+
+sub {
+ bottom: -.25em
+}
+
+figure {
+ margin: var(--universal-margin)
+}
+
+figcaption {
+ color: var(--secondary-fore-color)
+}
+
+a {
+ text-decoration: none
+}
+
+a:link {
+ color: var(--a-link-color)
+}
+
+a:visited {
+ color: var(--a-visited-color)
+}
+
+a:hover, a:focus {
+ text-decoration: underline
+}
+
+.container {
+ margin: 0 auto;
+ padding: 0 calc(1.5 * var(--universal-padding))
+}
+
+.row {
+ box-sizing: border-box;
+ display: flex;
+ flex: 0 1 auto;
+ flex-flow: row wrap
+}
+
+.col-sm, [class^='col-sm-'], [class^='col-sm-offset-'], .row[class*='cols-sm-']>* {
+ box-sizing: border-box;
+ flex: 0 0 auto;
+ padding: 0 calc(var(--universal-padding) / 2)
+}
+
+.col-sm, .row.cols-sm>* {
+ max-width: 100%;
+ flex-grow: 1;
+ flex-basis: 0
+}
+
+.col-sm-1, .row.cols-sm-1>* {
+ max-width: 8.33333%;
+ flex-basis: 8.33333%
+}
+
+.col-sm-offset-0 {
+ margin-left: 0
+}
+
+.col-sm-2, .row.cols-sm-2>* {
+ max-width: 16.66667%;
+ flex-basis: 16.66667%
+}
+
+.col-sm-offset-1 {
+ margin-left: 8.33333%
+}
+
+.col-sm-3, .row.cols-sm-3>* {
+ max-width: 25%;
+ flex-basis: 25%
+}
+
+.col-sm-offset-2 {
+ margin-left: 16.66667%
+}
+
+.col-sm-4, .row.cols-sm-4>* {
+ max-width: 33.33333%;
+ flex-basis: 33.33333%
+}
+
+.col-sm-offset-3 {
+ margin-left: 25%
+}
+
+.col-sm-5, .row.cols-sm-5>* {
+ max-width: 41.66667%;
+ flex-basis: 41.66667%
+}
+
+.col-sm-offset-4 {
+ margin-left: 33.33333%
+}
+
+.col-sm-6, .row.cols-sm-6>* {
+ max-width: 50%;
+ flex-basis: 50%
+}
+
+.col-sm-offset-5 {
+ margin-left: 41.66667%
+}
+
+.col-sm-7, .row.cols-sm-7>* {
+ max-width: 58.33333%;
+ flex-basis: 58.33333%
+}
+
+.col-sm-offset-6 {
+ margin-left: 50%
+}
+
+.col-sm-8, .row.cols-sm-8>* {
+ max-width: 66.66667%;
+ flex-basis: 66.66667%
+}
+
+.col-sm-offset-7 {
+ margin-left: 58.33333%
+}
+
+.col-sm-9, .row.cols-sm-9>* {
+ max-width: 75%;
+ flex-basis: 75%
+}
+
+.col-sm-offset-8 {
+ margin-left: 66.66667%
+}
+
+.col-sm-10, .row.cols-sm-10>* {
+ max-width: 83.33333%;
+ flex-basis: 83.33333%
+}
+
+.col-sm-offset-9 {
+ margin-left: 75%
+}
+
+.col-sm-11, .row.cols-sm-11>* {
+ max-width: 91.66667%;
+ flex-basis: 91.66667%
+}
+
+.col-sm-offset-10 {
+ margin-left: 83.33333%
+}
+
+.col-sm-12, .row.cols-sm-12>* {
+ max-width: 100%;
+ flex-basis: 100%
+}
+
+.col-sm-offset-11 {
+ margin-left: 91.66667%
+}
+
+.col-sm-normal {
+ order: initial
+}
+
+.col-sm-first {
+ order: -999
+}
+
+.col-sm-last {
+ order: 999
+}
+
+@media screen and (min-width: 768px) {
+ .col-md, [class^='col-md-'], [class^='col-md-offset-'], .row[class*='cols-md-']>* {
+ box-sizing: border-box;
+ flex: 0 0 auto;
+ padding: 0 calc(var(--universal-padding) / 2)
+ }
+ .col-md, .row.cols-md>* {
+ max-width: 100%;
+ flex-grow: 1;
+ flex-basis: 0
+ }
+ .col-md-1, .row.cols-md-1>* {
+ max-width: 8.33333%;
+ flex-basis: 8.33333%
+ }
+ .col-md-offset-0 {
+ margin-left: 0
+ }
+ .col-md-2, .row.cols-md-2>* {
+ max-width: 16.66667%;
+ flex-basis: 16.66667%
+ }
+ .col-md-offset-1 {
+ margin-left: 8.33333%
+ }
+ .col-md-3, .row.cols-md-3>* {
+ max-width: 25%;
+ flex-basis: 25%
+ }
+ .col-md-offset-2 {
+ margin-left: 16.66667%
+ }
+ .col-md-4, .row.cols-md-4>* {
+ max-width: 33.33333%;
+ flex-basis: 33.33333%
+ }
+ .col-md-offset-3 {
+ margin-left: 25%
+ }
+ .col-md-5, .row.cols-md-5>* {
+ max-width: 41.66667%;
+ flex-basis: 41.66667%
+ }
+ .col-md-offset-4 {
+ margin-left: 33.33333%
+ }
+ .col-md-6, .row.cols-md-6>* {
+ max-width: 50%;
+ flex-basis: 50%
+ }
+ .col-md-offset-5 {
+ margin-left: 41.66667%
+ }
+ .col-md-7, .row.cols-md-7>* {
+ max-width: 58.33333%;
+ flex-basis: 58.33333%
+ }
+ .col-md-offset-6 {
+ margin-left: 50%
+ }
+ .col-md-8, .row.cols-md-8>* {
+ max-width: 66.66667%;
+ flex-basis: 66.66667%
+ }
+ .col-md-offset-7 {
+ margin-left: 58.33333%
+ }
+ .col-md-9, .row.cols-md-9>* {
+ max-width: 75%;
+ flex-basis: 75%
+ }
+ .col-md-offset-8 {
+ margin-left: 66.66667%
+ }
+ .col-md-10, .row.cols-md-10>* {
+ max-width: 83.33333%;
+ flex-basis: 83.33333%
+ }
+ .col-md-offset-9 {
+ margin-left: 75%
+ }
+ .col-md-11, .row.cols-md-11>* {
+ max-width: 91.66667%;
+ flex-basis: 91.66667%
+ }
+ .col-md-offset-10 {
+ margin-left: 83.33333%
+ }
+ .col-md-12, .row.cols-md-12>* {
+ max-width: 100%;
+ flex-basis: 100%
+ }
+ .col-md-offset-11 {
+ margin-left: 91.66667%
+ }
+ .col-md-normal {
+ order: initial
+ }
+ .col-md-first {
+ order: -999
+ }
+ .col-md-last {
+ order: 999
+ }
+}
+
+@media screen and (min-width: 1280px) {
+ .col-lg, [class^='col-lg-'], [class^='col-lg-offset-'], .row[class*='cols-lg-']>* {
+ box-sizing: border-box;
+ flex: 0 0 auto;
+ padding: 0 calc(var(--universal-padding) / 2)
+ }
+ .col-lg, .row.cols-lg>* {
+ max-width: 100%;
+ flex-grow: 1;
+ flex-basis: 0
+ }
+ .col-lg-1, .row.cols-lg-1>* {
+ max-width: 8.33333%;
+ flex-basis: 8.33333%
+ }
+ .col-lg-offset-0 {
+ margin-left: 0
+ }
+ .col-lg-2, .row.cols-lg-2>* {
+ max-width: 16.66667%;
+ flex-basis: 16.66667%
+ }
+ .col-lg-offset-1 {
+ margin-left: 8.33333%
+ }
+ .col-lg-3, .row.cols-lg-3>* {
+ max-width: 25%;
+ flex-basis: 25%
+ }
+ .col-lg-offset-2 {
+ margin-left: 16.66667%
+ }
+ .col-lg-4, .row.cols-lg-4>* {
+ max-width: 33.33333%;
+ flex-basis: 33.33333%
+ }
+ .col-lg-offset-3 {
+ margin-left: 25%
+ }
+ .col-lg-5, .row.cols-lg-5>* {
+ max-width: 41.66667%;
+ flex-basis: 41.66667%
+ }
+ .col-lg-offset-4 {
+ margin-left: 33.33333%
+ }
+ .col-lg-6, .row.cols-lg-6>* {
+ max-width: 50%;
+ flex-basis: 50%
+ }
+ .col-lg-offset-5 {
+ margin-left: 41.66667%
+ }
+ .col-lg-7, .row.cols-lg-7>* {
+ max-width: 58.33333%;
+ flex-basis: 58.33333%
+ }
+ .col-lg-offset-6 {
+ margin-left: 50%
+ }
+ .col-lg-8, .row.cols-lg-8>* {
+ max-width: 66.66667%;
+ flex-basis: 66.66667%
+ }
+ .col-lg-offset-7 {
+ margin-left: 58.33333%
+ }
+ .col-lg-9, .row.cols-lg-9>* {
+ max-width: 75%;
+ flex-basis: 75%
+ }
+ .col-lg-offset-8 {
+ margin-left: 66.66667%
+ }
+ .col-lg-10, .row.cols-lg-10>* {
+ max-width: 83.33333%;
+ flex-basis: 83.33333%
+ }
+ .col-lg-offset-9 {
+ margin-left: 75%
+ }
+ .col-lg-11, .row.cols-lg-11>* {
+ max-width: 91.66667%;
+ flex-basis: 91.66667%
+ }
+ .col-lg-offset-10 {
+ margin-left: 83.33333%
+ }
+ .col-lg-12, .row.cols-lg-12>* {
+ max-width: 100%;
+ flex-basis: 100%
+ }
+ .col-lg-offset-11 {
+ margin-left: 91.66667%
+ }
+ .col-lg-normal {
+ order: initial
+ }
+ .col-lg-first {
+ order: -999
+ }
+ .col-lg-last {
+ order: 999
+ }
+}
+
+:root {
+ --card-back-color: #f8f8f8;
+ --card-fore-color: #111;
+ --card-border-color: #ddd
+}
+
+.card {
+ display: flex;
+ flex-direction: column;
+ justify-content: space-between;
+ align-self: center;
+ position: relative;
+ width: 100%;
+ background: var(--card-back-color);
+ color: var(--card-fore-color);
+ border: .0625rem solid var(--card-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: var(--universal-margin);
+ overflow: hidden
+}
+
+@media screen and (min-width: 320px) {
+ .card {
+ max-width: 320px
+ }
+}
+
+.card>.section {
+ background: var(--card-back-color);
+ color: var(--card-fore-color);
+ box-sizing: border-box;
+ margin: 0;
+ border: 0;
+ border-radius: 0;
+ border-bottom: .0625rem solid var(--card-border-color);
+ padding: var(--universal-padding);
+ width: 100%
+}
+
+.card>.section.media {
+ height: 200px;
+ padding: 0;
+ -o-object-fit: cover;
+ object-fit: cover
+}
+
+.card>.section:last-child {
+ border-bottom: 0
+}
+
+@media screen and (min-width: 240px) {
+ .card.small {
+ max-width: 240px
+ }
+}
+
+@media screen and (min-width: 480px) {
+ .card.large {
+ max-width: 480px
+ }
+}
+
+.card.fluid {
+ max-width: 100%;
+ width: auto
+}
+
+.card.warning {
+ --card-back-color: #ffca28;
+ --card-border-color: #e8b825
+}
+
+.card.error {
+ --card-back-color: #b71c1c;
+ --card-fore-color: #f8f8f8;
+ --card-border-color: #a71a1a
+}
+
+.card>.section.dark {
+ --card-back-color: #e0e0e0
+}
+
+.card>.section.double-padded {
+ padding: calc(1.5 * var(--universal-padding))
+}
+
+:root {
+ --form-back-color: #f0f0f0;
+ --form-fore-color: #111;
+ --form-border-color: #ddd;
+ --input-back-color: #f8f8f8;
+ --input-fore-color: #111;
+ --input-border-color: #ddd;
+ --input-focus-color: #0288d1;
+ --input-invalid-color: #d32f2f;
+ --button-back-color: #e2e2e2;
+ --button-hover-back-color: #dcdcdc;
+ --button-fore-color: #212121;
+ --button-border-color: rgba(0, 0, 0, 0);
+ --button-hover-border-color: rgba(0, 0, 0, 0);
+ --button-group-border-color: rgba(124, 124, 124, 0.54)
+}
+
+form {
+ background: var(--form-back-color);
+ color: var(--form-fore-color);
+ border: .0625rem solid var(--form-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: var(--universal-margin);
+ padding: calc(2 * var(--universal-padding)) var(--universal-padding)
+}
+
+fieldset {
+ border: .0625rem solid var(--form-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: calc(var(--universal-margin) / 4);
+ padding: var(--universal-padding)
+}
+
+legend {
+ box-sizing: border-box;
+ display: table;
+ max-width: 100%;
+ white-space: normal;
+ font-weight: 700;
+ padding: calc(var(--universal-padding) / 2)
+}
+
+label {
+ padding: calc(var(--universal-padding) / 2) var(--universal-padding)
+}
+
+.input-group {
+ display: inline-block
+}
+
+.input-group.fluid {
+ display: flex;
+ align-items: center;
+ justify-content: center
+}
+
+.input-group.fluid>input {
+ max-width: 100%;
+ flex-grow: 1;
+ flex-basis: 0px
+}
+
+@media screen and (max-width: 767px) {
+ .input-group.fluid {
+ align-items: stretch;
+ flex-direction: column
+ }
+}
+
+.input-group.vertical {
+ display: flex;
+ align-items: stretch;
+ flex-direction: column
+}
+
+.input-group.vertical>input {
+ max-width: 100%;
+ flex-grow: 1;
+ flex-basis: 0px
+}
+
+[type="number"]::-webkit-inner-spin-button, [type="number"]::-webkit-outer-spin-button {
+ height: auto
+}
+
+[type="search"] {
+ -webkit-appearance: textfield;
+ outline-offset: -2px
+}
+
+[type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
+ -webkit-appearance: none
+}
+
+input:not([type]), [type="text"], [type="email"], [type="number"], [type="search"], [type="password"], [type="url"], [type="tel"], [type="checkbox"], [type="radio"], textarea, select {
+ box-sizing: border-box;
+ background: var(--input-back-color);
+ color: var(--input-fore-color);
+ border: .0625rem solid var(--input-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: calc(var(--universal-margin) / 2);
+ padding: var(--universal-padding) calc(1.5 * var(--universal-padding))
+}
+
+input:not([type="button"]):not([type="submit"]):not([type="reset"]):hover, input:not([type="button"]):not([type="submit"]):not([type="reset"]):focus, textarea:hover, textarea:focus, select:hover, select:focus {
+ border-color: var(--input-focus-color);
+ box-shadow: none
+}
+
+input:not([type="button"]):not([type="submit"]):not([type="reset"]):invalid, input:not([type="button"]):not([type="submit"]):not([type="reset"]):focus:invalid, textarea:invalid, textarea:focus:invalid, select:invalid, select:focus:invalid {
+ border-color: var(--input-invalid-color);
+ box-shadow: none
+}
+
+input:not([type="button"]):not([type="submit"]):not([type="reset"])[readonly], textarea[readonly], select[readonly] {
+ background: var(--secondary-back-color)
+}
+
+select {
+ max-width: 100%
+}
+
+option {
+ overflow: hidden;
+ text-overflow: ellipsis
+}
+
+[type="checkbox"], [type="radio"] {
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ appearance: none;
+ position: relative;
+ height: calc(1rem + var(--universal-padding) / 2);
+ width: calc(1rem + var(--universal-padding) / 2);
+ vertical-align: text-bottom;
+ padding: 0;
+ flex-basis: calc(1rem + var(--universal-padding) / 2) !important;
+ flex-grow: 0 !important
+}
+
+[type="checkbox"]:checked:before, [type="radio"]:checked:before {
+ position: absolute
+}
+
+[type="checkbox"]:checked:before {
+ content: '\2713';
+ font-size: calc(1rem + var(--universal-padding) / 2);
+ top: calc(0rem - var(--universal-padding));
+ left: calc(var(--universal-padding) / 4)
+}
+
+[type="radio"] {
+ border-radius: 100%
+}
+
+[type="radio"]:checked:before {
+ border-radius: 100%;
+ content: '';
+ top: calc(.0625rem + var(--universal-padding) / 2);
+ left: calc(.0625rem + var(--universal-padding) / 2);
+ background: var(--input-fore-color);
+ width: 0.5rem;
+ height: 0.5rem
+}
+
+:placeholder-shown {
+ color: var(--input-fore-color)
+}
+
+::-ms-placeholder {
+ color: var(--input-fore-color);
+ opacity: 0.54
+}
+
+button::-moz-focus-inner, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
+ border-style: none;
+ padding: 0
+}
+
+button, html [type="button"], [type="reset"], [type="submit"] {
+ -webkit-appearance: button
+}
+
+button {
+ overflow: visible;
+ text-transform: none
+}
+
+button, [type="button"], [type="submit"], [type="reset"], a.button, label.button, .button, a[role="button"], label[role="button"], [role="button"] {
+ display: inline-block;
+ background: var(--button-back-color);
+ color: var(--button-fore-color);
+ border: .0625rem solid var(--button-border-color);
+ border-radius: var(--universal-border-radius);
+ padding: var(--universal-padding) calc(1.5 * var(--universal-padding));
+ margin: var(--universal-margin);
+ text-decoration: none;
+ cursor: pointer;
+ transition: background 0.3s
+}
+
+button:hover, button:focus, [type="button"]:hover, [type="button"]:focus, [type="submit"]:hover, [type="submit"]:focus, [type="reset"]:hover, [type="reset"]:focus, a.button:hover, a.button:focus, label.button:hover, label.button:focus, .button:hover, .button:focus, a[role="button"]:hover, a[role="button"]:focus, label[role="button"]:hover, label[role="button"]:focus, [role="button"]:hover, [role="button"]:focus {
+ background: var(--button-hover-back-color);
+ border-color: var(--button-hover-border-color)
+}
+
+input:disabled, input[disabled], textarea:disabled, textarea[disabled], select:disabled, select[disabled], button:disabled, button[disabled], .button:disabled, .button[disabled], [role="button"]:disabled, [role="button"][disabled] {
+ cursor: not-allowed;
+ opacity: .75
+}
+
+.button-group {
+ display: flex;
+ border: .0625rem solid var(--button-group-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: var(--universal-margin)
+}
+
+.button-group>button, .button-group [type="button"], .button-group>[type="submit"], .button-group>[type="reset"], .button-group>.button, .button-group>[role="button"] {
+ margin: 0;
+ max-width: 100%;
+ flex: 1 1 auto;
+ text-align: center;
+ border: 0;
+ border-radius: 0;
+ box-shadow: none
+}
+
+.button-group>:not(:first-child) {
+ border-left: .0625rem solid var(--button-group-border-color)
+}
+
+@media screen and (max-width: 767px) {
+ .button-group {
+ flex-direction: column
+ }
+ .button-group>:not(:first-child) {
+ border: 0;
+ border-top: .0625rem solid var(--button-group-border-color)
+ }
+}
+
+button.primary, [type="button"].primary, [type="submit"].primary, [type="reset"].primary, .button.primary, [role="button"].primary {
+ --button-back-color: #1976d2;
+ --button-fore-color: #f8f8f8
+}
+
+button.primary:hover, button.primary:focus, [type="button"].primary:hover, [type="button"].primary:focus, [type="submit"].primary:hover, [type="submit"].primary:focus, [type="reset"].primary:hover, [type="reset"].primary:focus, .button.primary:hover, .button.primary:focus, [role="button"].primary:hover, [role="button"].primary:focus {
+ --button-hover-back-color: #1565c0
+}
+
+button.secondary, [type="button"].secondary, [type="submit"].secondary, [type="reset"].secondary, .button.secondary, [role="button"].secondary {
+ --button-back-color: #d32f2f;
+ --button-fore-color: #f8f8f8
+}
+
+button.secondary:hover, button.secondary:focus, [type="button"].secondary:hover, [type="button"].secondary:focus, [type="submit"].secondary:hover, [type="submit"].secondary:focus, [type="reset"].secondary:hover, [type="reset"].secondary:focus, .button.secondary:hover, .button.secondary:focus, [role="button"].secondary:hover, [role="button"].secondary:focus {
+ --button-hover-back-color: #c62828
+}
+
+button.tertiary, [type="button"].tertiary, [type="submit"].tertiary, [type="reset"].tertiary, .button.tertiary, [role="button"].tertiary {
+ --button-back-color: #308732;
+ --button-fore-color: #f8f8f8
+}
+
+button.tertiary:hover, button.tertiary:focus, [type="button"].tertiary:hover, [type="button"].tertiary:focus, [type="submit"].tertiary:hover, [type="submit"].tertiary:focus, [type="reset"].tertiary:hover, [type="reset"].tertiary:focus, .button.tertiary:hover, .button.tertiary:focus, [role="button"].tertiary:hover, [role="button"].tertiary:focus {
+ --button-hover-back-color: #277529
+}
+
+button.inverse, [type="button"].inverse, [type="submit"].inverse, [type="reset"].inverse, .button.inverse, [role="button"].inverse {
+ --button-back-color: #212121;
+ --button-fore-color: #f8f8f8
+}
+
+button.inverse:hover, button.inverse:focus, [type="button"].inverse:hover, [type="button"].inverse:focus, [type="submit"].inverse:hover, [type="submit"].inverse:focus, [type="reset"].inverse:hover, [type="reset"].inverse:focus, .button.inverse:hover, .button.inverse:focus, [role="button"].inverse:hover, [role="button"].inverse:focus {
+ --button-hover-back-color: #111
+}
+
+button.small, [type="button"].small, [type="submit"].small, [type="reset"].small, .button.small, [role="button"].small {
+ padding: calc(0.5 * var(--universal-padding)) calc(0.75 * var(--universal-padding));
+ margin: var(--universal-margin)
+}
+
+button.large, [type="button"].large, [type="submit"].large, [type="reset"].large, .button.large, [role="button"].large {
+ padding: calc(1.5 * var(--universal-padding)) calc(2 * var(--universal-padding));
+ margin: var(--universal-margin)
+}
+
+:root {
+ --header-back-color: #f8f8f8;
+ --header-hover-back-color: #f0f0f0;
+ --header-fore-color: #444;
+ --header-border-color: #ddd;
+ --nav-back-color: #f8f8f8;
+ --nav-hover-back-color: #f0f0f0;
+ --nav-fore-color: #444;
+ --nav-border-color: #ddd;
+ --nav-link-color: #0277bd;
+ --footer-fore-color: #444;
+ --footer-back-color: #f8f8f8;
+ --footer-border-color: #ddd;
+ --footer-link-color: #0277bd;
+ --drawer-back-color: #f8f8f8;
+ --drawer-hover-back-color: #f0f0f0;
+ --drawer-border-color: #ddd;
+ --drawer-close-color: #444
+}
+
+header {
+ height: 3.1875rem;
+ background: var(--header-back-color);
+ color: var(--header-fore-color);
+ border-bottom: .0625rem solid var(--header-border-color);
+ padding: calc(var(--universal-padding) / 4) 0;
+ white-space: nowrap;
+ overflow-x: auto;
+ overflow-y: hidden
+}
+
+header.row {
+ box-sizing: content-box
+}
+
+header .logo {
+ color: var(--header-fore-color);
+ font-size: 1.75rem;
+ padding: var(--universal-padding) calc(2 * var(--universal-padding));
+ text-decoration: none
+}
+
+header button, header [type="button"], header .button, header [role="button"] {
+ box-sizing: border-box;
+ position: relative;
+ top: calc(0rem - var(--universal-padding) / 4);
+ height: calc(3.1875rem + var(--universal-padding) / 2);
+ background: var(--header-back-color);
+ line-height: calc(3.1875rem - var(--universal-padding) * 1.5);
+ text-align: center;
+ color: var(--header-fore-color);
+ border: 0;
+ border-radius: 0;
+ margin: 0;
+ text-transform: uppercase
+}
+
+header button:hover, header button:focus, header [type="button"]:hover, header [type="button"]:focus, header .button:hover, header .button:focus, header [role="button"]:hover, header [role="button"]:focus {
+ background: var(--header-hover-back-color)
+}
+
+nav {
+ background: var(--nav-back-color);
+ color: var(--nav-fore-color);
+ border: .0625rem solid var(--nav-border-color);
+ border-radius: var(--universal-border-radius);
+ margin: var(--universal-margin)
+}
+
+nav * {
+ padding: var(--universal-padding) calc(1.5 * var(--universal-padding))
+}
+
+nav a, nav a:visited {
+ display: block;
+ color: var(--nav-link-color);
+ border-radius: var(--universal-border-radius);
+ transition: background 0.3s
+}
+
+nav a:hover, nav a:focus, nav a:visited:hover, nav a:visited:focus {
+ text-decoration: none;
+ background: var(--nav-hover-back-color)
+}
+
+nav .sublink-1 {
+ position: relative;
+ margin-left: calc(2 * var(--universal-padding))
+}
+
+nav .sublink-1:before {
+ position: absolute;
+ left: calc(var(--universal-padding) - 1 * var(--universal-padding));
+ top: -.0625rem;
+ content: '';
+ height: 100%;
+ border: .0625rem solid var(--nav-border-color);
+ border-left: 0
+}
+
+nav .sublink-2 {
+ position: relative;
+ margin-left: calc(4 * var(--universal-padding))
+}
+
+nav .sublink-2:before {
+ position: absolute;
+ left: calc(var(--universal-padding) - 3 * var(--universal-padding));
+ top: -.0625rem;
+ content: '';
+ height: 100%;
+ border: .0625rem solid var(--nav-border-color);
+ border-left: 0
+}
+
+footer {
+ background: var(--footer-back-color);
+ color: var(--footer-fore-color);
+ border-top: .0625rem solid var(--footer-border-color);
+ padding: calc(2 * var(--universal-padding)) var(--universal-padding);
+ font-size: .875rem
+}
+
+footer a, footer a:visited {
+ color: var(--footer-link-color)
+}
+
+header.sticky {
+ position: -webkit-sticky;
+ position: sticky;
+ z-index: 1101;
+ top: 0
+}
+
+footer.sticky {
+ position: -webkit-sticky;
+ position: sticky;
+ z-index: 1101;
+ bottom: 0
+}
+
+.drawer-toggle:before {
+ display: inline-block;
+ position: relative;
+ vertical-align: bottom;
+ content: '\00a0\2261\00a0';
+ font-size: 1.5em
+}
+
+@media screen and (min-width: 768px) {
+ .drawer-toggle:not(.persistent) {
+ display: none
+ }
+}
+
+[type="checkbox"].drawer {
+ height: 1px;
+ width: 1px;
+ margin: -1px;
+ overflow: hidden;
+ position: absolute;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%)
+}
+
+[type="checkbox"].drawer+* {
+ display: block;
+ box-sizing: border-box;
+ position: fixed;
+ top: 0;
+ width: 320px;
+ height: 100vh;
+ overflow-y: auto;
+ background: var(--drawer-back-color);
+ border: .0625rem solid var(--drawer-border-color);
+ border-radius: 0;
+ margin: 0;
+ z-index: 1110;
+ right: -320px;
+ transition: right 0.3s
+}
+
+[type="checkbox"].drawer+* .drawer-close {
+ position: absolute;
+ top: var(--universal-margin);
+ right: var(--universal-margin);
+ z-index: 1111;
+ width: 2rem;
+ height: 2rem;
+ border-radius: var(--universal-border-radius);
+ padding: var(--universal-padding);
+ margin: 0;
+ cursor: pointer;
+ transition: background 0.3s
+}
+
+[type="checkbox"].drawer+* .drawer-close:before {
+ display: block;
+ content: '\00D7';
+ color: var(--drawer-close-color);
+ position: relative;
+ font-size: 2rem;
+ line-height: 1;
+ text-align: center
+}
+
+[type="checkbox"].drawer+* .drawer-close:hover, [type="checkbox"].drawer+* .drawer-close:focus {
+ background: var(--drawer-hover-back-color)
+}
+
+@media screen and (max-width: 320px) {
+ [type="checkbox"].drawer+* {
+ width: 100%
+ }
+}
+
+[type="checkbox"].drawer:checked+* {
+ right: 0
+}
+
+@media screen and (min-width: 768px) {
+ [type="checkbox"].drawer:not(.persistent)+* {
+ position: static;
+ height: 100%;
+ z-index: 1100
+ }
+ [type="checkbox"].drawer:not(.persistent)+* .drawer-close {
+ display: none
+ }
+}
+
+:root {
+ --table-border-color: #aaa;
+ --table-border-separator-color: #666;
+ --table-head-back-color: #e6e6e6;
+ --table-head-fore-color: #111;
+ --table-body-back-color: #f8f8f8;
+ --table-body-fore-color: #111;
+ --table-body-alt-back-color: #eee
+}
+
+table {
+ border-collapse: separate;
+ border-spacing: 0;
+ margin: 0;
+ display: flex;
+ flex: 0 1 auto;
+ flex-flow: row wrap;
+ padding: var(--universal-padding);
+ padding-top: 0
+}
+
+table caption {
+ font-size: 1.5rem;
+ margin: calc(2 * var(--universal-margin)) 0;
+ max-width: 100%;
+ flex: 0 0 100%
+}
+
+table thead, table tbody {
+ display: flex;
+ flex-flow: row wrap;
+ border: .0625rem solid var(--table-border-color)
+}
+
+table thead {
+ z-index: 999;
+ border-radius: var(--universal-border-radius) var(--universal-border-radius) 0 0;
+ border-bottom: .0625rem solid var(--table-border-separator-color)
+}
+
+table tbody {
+ border-top: 0;
+ margin-top: calc(0 - var(--universal-margin));
+ border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius)
+}
+
+table tr {
+ display: flex;
+ padding: 0
+}
+
+table th, table td {
+ padding: calc(2 * var(--universal-padding))
+}
+
+table th {
+ text-align: left;
+ background: var(--table-head-back-color);
+ color: var(--table-head-fore-color)
+}
+
+table td {
+ background: var(--table-body-back-color);
+ color: var(--table-body-fore-color);
+ border-top: .0625rem solid var(--table-border-color)
+}
+
+table:not(.horizontal) {
+ overflow: auto;
+ max-height: 400px
+}
+
+table:not(.horizontal) thead, table:not(.horizontal) tbody {
+ max-width: 100%;
+ flex: 0 0 100%
+}
+
+table:not(.horizontal) tr {
+ flex-flow: row wrap;
+ flex: 0 0 100%
+}
+
+table:not(.horizontal) th, table:not(.horizontal) td {
+ flex: 1 0 0%;
+ overflow: hidden;
+ text-overflow: ellipsis
+}
+
+table:not(.horizontal) thead {
+ position: sticky;
+ top: 0
+}
+
+table:not(.horizontal) tbody tr:first-child td {
+ border-top: 0
+}
+
+table.horizontal {
+ border: 0
+}
+
+table.horizontal thead, table.horizontal tbody {
+ border: 0;
+ flex: .2 0 0;
+ flex-flow: row nowrap
+}
+
+table.horizontal tbody {
+ overflow: auto;
+ justify-content: space-between;
+ flex: .8 0 0;
+ margin-left: 0;
+ padding-bottom: calc(var(--universal-padding) / 4)
+}
+
+table.horizontal tr {
+ flex-direction: column;
+ flex: 1 0 auto
+}
+
+table.horizontal th, table.horizontal td {
+ width: auto;
+ border: 0;
+ border-bottom: .0625rem solid var(--table-border-color)
+}
+
+table.horizontal th:not(:first-child), table.horizontal td:not(:first-child) {
+ border-top: 0
+}
+
+table.horizontal th {
+ text-align: right;
+ border-left: .0625rem solid var(--table-border-color);
+ border-right: .0625rem solid var(--table-border-separator-color)
+}
+
+table.horizontal thead tr:first-child {
+ padding-left: 0
+}
+
+table.horizontal th:first-child, table.horizontal td:first-child {
+ border-top: .0625rem solid var(--table-border-color)
+}
+
+table.horizontal tbody tr:last-child td {
+ border-right: .0625rem solid var(--table-border-color)
+}
+
+table.horizontal tbody tr:last-child td:first-child {
+ border-top-right-radius: 0.25rem
+}
+
+table.horizontal tbody tr:last-child td:last-child {
+ border-bottom-right-radius: 0.25rem
+}
+
+table.horizontal thead tr:first-child th:first-child {
+ border-top-left-radius: 0.25rem
+}
+
+table.horizontal thead tr:first-child th:last-child {
+ border-bottom-left-radius: 0.25rem
+}
+
+@media screen and (max-width: 767px) {
+ table, table.horizontal {
+ border-collapse: collapse;
+ border: 0;
+ width: 100%;
+ display: table
+ }
+ table thead, table th, table.horizontal thead, table.horizontal th {
+ border: 0;
+ height: 1px;
+ width: 1px;
+ margin: -1px;
+ overflow: hidden;
+ padding: 0;
+ position: absolute;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%)
+ }
+ table tbody, table.horizontal tbody {
+ border: 0;
+ display: table-row-group
+ }
+ table tr, table.horizontal tr {
+ display: block;
+ border: .0625rem solid var(--table-border-color);
+ border-radius: var(--universal-border-radius);
+ background: #fafafa;
+ padding: var(--universal-padding);
+ margin: var(--universal-margin);
+ margin-bottom: calc(2 * var(--universal-margin))
+ }
+ table th, table td, table.horizontal th, table.horizontal td {
+ width: auto
+ }
+ table td, table.horizontal td {
+ display: block;
+ border: 0;
+ text-align: right
+ }
+ table td:before, table.horizontal td:before {
+ content: attr(data-label);
+ float: left;
+ font-weight: 600
+ }
+ table th:first-child, table td:first-child, table.horizontal th:first-child, table.horizontal td:first-child {
+ border-top: 0
+ }
+ table tbody tr:last-child td, table.horizontal tbody tr:last-child td {
+ border-right: 0
+ }
+}
+
+:root {
+ --table-body-alt-back-color: #eee
+}
+
+table.striped tr:nth-of-type(2n)>td {
+ background: var(--table-body-alt-back-color)
+}
+
+@media screen and (max-width: 768px) {
+ table.striped tr:nth-of-type(2n) {
+ background: var(--table-body-alt-back-color)
+ }
+}
+
+:root {
+ --table-body-hover-back-color: #90caf9
+}
+
+table.hoverable tr:hover, table.hoverable tr:hover>td, table.hoverable tr:focus, table.hoverable tr:focus>td {
+ background: var(--table-body-hover-back-color)
+}
+
+@media screen and (max-width: 768px) {
+ table.hoverable tr:hover, table.hoverable tr:hover>td, table.hoverable tr:focus, table.hoverable tr:focus>td {
+ background: var(--table-body-hover-back-color)
+ }
+}
+
+:root {
+ --mark-back-color: #0277bd;
+ --mark-fore-color: #fafafa
+}
+
+mark {
+ background: var(--mark-back-color);
+ color: var(--mark-fore-color);
+ font-size: .95em;
+ line-height: 1em;
+ border-radius: var(--universal-border-radius);
+ padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2)
+}
+
+mark.inline-block {
+ display: inline-block;
+ font-size: 1em;
+ line-height: 1.5;
+ padding: calc(var(--universal-padding) / 2) var(--universal-padding)
+}
+
+:root {
+ --toast-back-color: #424242;
+ --toast-fore-color: #fafafa
+}
+
+.toast {
+ position: fixed;
+ bottom: calc(var(--universal-margin) * 3);
+ left: 50%;
+ transform: translate(-50%, -50%);
+ z-index: 1111;
+ color: var(--toast-fore-color);
+ background: var(--toast-back-color);
+ border-radius: calc(var(--universal-border-radius) * 16);
+ padding: var(--universal-padding) calc(var(--universal-padding) * 3)
+}
+
+:root {
+ --tooltip-back-color: #212121;
+ --tooltip-fore-color: #fafafa
+}
+
+.tooltip {
+ position: relative;
+ display: inline-block
+}
+
+.tooltip:before, .tooltip:after {
+ position: absolute;
+ opacity: 0;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%);
+ transition: all 0.3s;
+ z-index: 1010;
+ left: 50%
+}
+
+.tooltip:not(.bottom):before, .tooltip:not(.bottom):after {
+ bottom: 75%
+}
+
+.tooltip.bottom:before, .tooltip.bottom:after {
+ top: 75%
+}
+
+.tooltip:hover:before, .tooltip:hover:after, .tooltip:focus:before, .tooltip:focus:after {
+ opacity: 1;
+ clip: auto;
+ -webkit-clip-path: inset(0%);
+ clip-path: inset(0%)
+}
+
+.tooltip:before {
+ content: '';
+ background: transparent;
+ border: var(--universal-margin) solid transparent;
+ left: calc(50% - var(--universal-margin))
+}
+
+.tooltip:not(.bottom):before {
+ border-top-color: #212121
+}
+
+.tooltip.bottom:before {
+ border-bottom-color: #212121
+}
+
+.tooltip:after {
+ content: attr(aria-label);
+ color: var(--tooltip-fore-color);
+ background: var(--tooltip-back-color);
+ border-radius: var(--universal-border-radius);
+ padding: var(--universal-padding);
+ white-space: nowrap;
+ transform: translateX(-50%)
+}
+
+.tooltip:not(.bottom):after {
+ margin-bottom: calc(2 * var(--universal-margin))
+}
+
+.tooltip.bottom:after {
+ margin-top: calc(2 * var(--universal-margin))
+}
+
+:root {
+ --modal-overlay-color: rgba(0, 0, 0, 0.45);
+ --modal-close-color: #444;
+ --modal-close-hover-color: #f0f0f0
+}
+
+[type="checkbox"].modal {
+ height: 1px;
+ width: 1px;
+ margin: -1px;
+ overflow: hidden;
+ position: absolute;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%)
+}
+
+[type="checkbox"].modal+div {
+ position: fixed;
+ top: 0;
+ left: 0;
+ display: none;
+ width: 100vw;
+ height: 100vh;
+ background: var(--modal-overlay-color)
+}
+
+[type="checkbox"].modal+div .card {
+ margin: 0 auto;
+ max-height: 50vh;
+ overflow: auto
+}
+
+[type="checkbox"].modal+div .card .modal-close {
+ position: absolute;
+ top: 0;
+ right: 0;
+ width: 1.75rem;
+ height: 1.75rem;
+ border-radius: var(--universal-border-radius);
+ padding: var(--universal-padding);
+ margin: 0;
+ cursor: pointer;
+ transition: background 0.3s
+}
+
+[type="checkbox"].modal+div .card .modal-close:before {
+ display: block;
+ content: '\00D7';
+ color: var(--modal-close-color);
+ position: relative;
+ font-size: 1.75rem;
+ line-height: 1;
+ text-align: center
+}
+
+[type="checkbox"].modal+div .card .modal-close:hover, [type="checkbox"].modal+div .card .modal-close:focus {
+ background: var(--modal-close-hover-color)
+}
+
+[type="checkbox"].modal:checked+div {
+ display: flex;
+ flex: 0 1 auto;
+ z-index: 1200
+}
+
+[type="checkbox"].modal:checked+div .card .modal-close {
+ z-index: 1211
+}
+
+:root {
+ --collapse-label-back-color: #e8e8e8;
+ --collapse-label-fore-color: #212121;
+ --collapse-label-hover-back-color: #f0f0f0;
+ --collapse-selected-label-back-color: #ececec;
+ --collapse-border-color: #ddd;
+ --collapse-content-back-color: #fafafa;
+ --collapse-selected-label-border-color: #0277bd
+}
+
+.collapse {
+ width: calc(100% - 2 * var(--universal-margin));
+ opacity: 1;
+ display: flex;
+ flex-direction: column;
+ margin: var(--universal-margin);
+ border-radius: var(--universal-border-radius)
+}
+
+.collapse>[type="radio"], .collapse>[type="checkbox"] {
+ height: 1px;
+ width: 1px;
+ margin: -1px;
+ overflow: hidden;
+ position: absolute;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%)
+}
+
+.collapse>label {
+ flex-grow: 1;
+ display: inline-block;
+ height: 1.5rem;
+ cursor: pointer;
+ transition: background 0.3s;
+ color: var(--collapse-label-fore-color);
+ background: var(--collapse-label-back-color);
+ border: .0625rem solid var(--collapse-border-color);
+ padding: calc(1.5 * var(--universal-padding))
+}
+
+.collapse>label:hover, .collapse>label:focus {
+ background: var(--collapse-label-hover-back-color)
+}
+
+.collapse>label+div {
+ flex-basis: auto;
+ height: 1px;
+ width: 1px;
+ margin: -1px;
+ overflow: hidden;
+ position: absolute;
+ clip: rect(0 0 0 0);
+ -webkit-clip-path: inset(100%);
+ clip-path: inset(100%);
+ transition: max-height 0.3s;
+ max-height: 1px
+}
+
+.collapse>:checked+label {
+ background: var(--collapse-selected-label-back-color);
+ border-bottom-color: var(--collapse-selected-label-border-color)
+}
+
+.collapse>:checked+label+div {
+ box-sizing: border-box;
+ position: relative;
+ width: 100%;
+ height: auto;
+ overflow: auto;
+ margin: 0;
+ background: var(--collapse-content-back-color);
+ border: .0625rem solid var(--collapse-border-color);
+ border-top: 0;
+ padding: var(--universal-padding);
+ clip: auto;
+ -webkit-clip-path: inset(0%);
+ clip-path: inset(0%);
+ max-height: 400px
+}
+
+.collapse>label:not(:first-of-type) {
+ border-top: 0
+}
+
+.collapse>label:first-of-type {
+ border-radius: var(--universal-border-radius) var(--universal-border-radius) 0 0
+}
+
+.collapse>label:last-of-type:not(:first-of-type) {
+ border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius)
+}
+
+.collapse>label:last-of-type:first-of-type {
+ border-radius: var(--universal-border-radius)
+}
+
+.collapse>:checked:last-of-type:not(:first-of-type)+label {
+ border-radius: 0
+}
+
+.collapse>:checked:last-of-type+label+div {
+ border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius)
+}
+
+mark.secondary {
+ --mark-back-color: #d32f2f
+}
+
+mark.tertiary {
+ --mark-back-color: #308732
+}
+
+mark.tag {
+ padding: calc(var(--universal-padding)/2) var(--universal-padding);
+ border-radius: 1em
+}
+
+:root {
+ --progress-back-color: #ddd;
+ --progress-fore-color: #555
+}
+
+progress {
+ display: block;
+ vertical-align: baseline;
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ appearance: none;
+ height: .75rem;
+ width: calc(100% - 2 * var(--universal-margin));
+ margin: var(--universal-margin);
+ border: 0;
+ border-radius: calc(2 * var(--universal-border-radius));
+ background: var(--progress-back-color);
+ color: var(--progress-fore-color)
+}
+
+progress::-webkit-progress-value {
+ background: var(--progress-fore-color);
+ border-top-left-radius: calc(2 * var(--universal-border-radius));
+ border-bottom-left-radius: calc(2 * var(--universal-border-radius))
+}
+
+progress::-webkit-progress-bar {
+ background: var(--progress-back-color)
+}
+
+progress::-moz-progress-bar {
+ background: var(--progress-fore-color);
+ border-top-left-radius: calc(2 * var(--universal-border-radius));
+ border-bottom-left-radius: calc(2 * var(--universal-border-radius))
+}
+
+progress[value="1000"]::-webkit-progress-value {
+ border-radius: calc(2 * var(--universal-border-radius))
+}
+
+progress[value="1000"]::-moz-progress-bar {
+ border-radius: calc(2 * var(--universal-border-radius))
+}
+
+progress.inline {
+ display: inline-block;
+ vertical-align: middle;
+ width: 60%
+}
+
+:root {
+ --spinner-back-color: #ddd;
+ --spinner-fore-color: #555
+}
+
+@keyframes spinner-donut-anim {
+ 0% {
+ transform: rotate(0deg)
+ }
+ 100% {
+ transform: rotate(360deg)
+ }
+}
+
+.spinner {
+ display: inline-block;
+ margin: var(--universal-margin);
+ border: .25rem solid var(--spinner-back-color);
+ border-left: .25rem solid var(--spinner-fore-color);
+ border-radius: 50%;
+ width: 1.25rem;
+ height: 1.25rem;
+ animation: spinner-donut-anim 1.2s linear infinite
+}
+
+progress.primary {
+ --progress-fore-color: #1976d2
+}
+
+progress.secondary {
+ --progress-fore-color: #d32f2f
+}
+
+progress.tertiary {
+ --progress-fore-color: #308732
+}
+
+.spinner.primary {
+ --spinner-fore-color: #1976d2
+}
+
+.spinner.secondary {
+ --spinner-fore-color: #d32f2f
+}
+
+.spinner.tertiary {
+ --spinner-fore-color: #308732
+}
+
+span[class^='icon-'] {
+ display: inline-block;
+ height: 1em;
+ width: 1em;
+ vertical-align: -0.125em;
+ background-size: contain;
+ margin: 0 calc(var(--universal-margin) / 4)
+}
+
+span[class^='icon-'].secondary {
+ -webkit-filter: invert(25%);
+ filter: invert(25%)
+}
+
+span[class^='icon-'].inverse {
+ -webkit-filter: invert(100%);
+ filter: invert(100%)
+}
+
+span.icon-alert {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12' y2='16'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-bookmark {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21l-7-5-7 5V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2z'%3E%3C/path%3E%3C/svg%3E")
+}
+
+span.icon-calendar {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-credit {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='4' width='22' height='16' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='1' y1='10' x2='23' y2='10'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-edit {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 14.66V20a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h5.34'%3E%3C/path%3E%3Cpolygon points='18 2 22 6 12 16 8 16 8 12 18 2'%3E%3C/polygon%3E%3C/svg%3E")
+}
+
+span.icon-link {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'%3E%3C/path%3E%3Cpolyline points='15 3 21 3 21 9'%3E%3C/polyline%3E%3Cline x1='10' y1='14' x2='21' y2='3'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-help {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='17' x2='12' y2='17'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-home {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'%3E%3C/path%3E%3Cpolyline points='9 22 9 12 15 12 15 22'%3E%3C/polyline%3E%3C/svg%3E")
+}
+
+span.icon-info {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='16' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='8' x2='12' y2='8'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-lock {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'%3E%3C/path%3E%3C/svg%3E")
+}
+
+span.icon-mail {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'%3E%3C/path%3E%3Cpolyline points='22,6 12,13 2,6'%3E%3C/polyline%3E%3C/svg%3E")
+}
+
+span.icon-location {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'%3E%3C/path%3E%3Ccircle cx='12' cy='10' r='3'%3E%3C/circle%3E%3C/svg%3E")
+}
+
+span.icon-phone {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'%3E%3C/path%3E%3C/svg%3E")
+}
+
+span.icon-rss {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11a9 9 0 0 1 9 9'%3E%3C/path%3E%3Cpath d='M4 4a16 16 0 0 1 16 16'%3E%3C/path%3E%3Ccircle cx='5' cy='19' r='1'%3E%3C/circle%3E%3C/svg%3E")
+}
+
+span.icon-search {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-settings {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'%3E%3C/circle%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z'%3E%3C/path%3E%3C/svg%3E")
+}
+
+span.icon-share {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='18' cy='5' r='3'%3E%3C/circle%3E%3Ccircle cx='6' cy='12' r='3'%3E%3C/circle%3E%3Ccircle cx='18' cy='19' r='3'%3E%3C/circle%3E%3Cline x1='8.59' y1='13.51' x2='15.42' y2='17.49'%3E%3C/line%3E%3Cline x1='15.41' y1='6.51' x2='8.59' y2='10.49'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-cart {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'%3E%3C/circle%3E%3Ccircle cx='20' cy='21' r='1'%3E%3C/circle%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'%3E%3C/path%3E%3C/svg%3E")
+}
+
+span.icon-upload {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'%3E%3C/path%3E%3Cpolyline points='17 8 12 3 7 8'%3E%3C/polyline%3E%3Cline x1='12' y1='3' x2='12' y2='15'%3E%3C/line%3E%3C/svg%3E")
+}
+
+span.icon-user {
+ background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E")
+}
+
+:root {
+ --generic-border-color: rgba(0, 0, 0, 0.3);
+ --generic-box-shadow: 0 .25rem .25rem 0 rgba(0, 0, 0, 0.125), 0 .125rem .125rem -.125rem rgba(0, 0, 0, 0.25)
+}
+
+.hidden {
+ display: none !important
+}
+
+.visually-hidden {
+ position: absolute !important;
+ width: 1px !important;
+ height: 1px !important;
+ margin: -1px !important;
+ border: 0 !important;
+ padding: 0 !important;
+ clip: rect(0 0 0 0) !important;
+ -webkit-clip-path: inset(100%) !important;
+ clip-path: inset(100%) !important;
+ overflow: hidden !important
+}
+
+.bordered {
+ border: .0625rem solid var(--generic-border-color) !important
+}
+
+.rounded {
+ border-radius: var(--universal-border-radius) !important
+}
+
+.circular {
+ border-radius: 50% !important
+}
+
+.shadowed {
+ box-shadow: var(--generic-box-shadow) !important
+}
+
+.responsive-margin {
+ margin: calc(var(--universal-margin) / 4) !important
+}
+
+@media screen and (min-width: 768px) {
+ .responsive-margin {
+ margin: calc(var(--universal-margin) / 2) !important
+ }
+}
+
+@media screen and (min-width: 1280px) {
+ .responsive-margin {
+ margin: var(--universal-margin) !important
+ }
+}
+
+.responsive-padding {
+ padding: calc(var(--universal-padding) / 4) !important
+}
+
+@media screen and (min-width: 768px) {
+ .responsive-padding {
+ padding: calc(var(--universal-padding) / 2) !important
+ }
+}
+
+@media screen and (min-width: 1280px) {
+ .responsive-padding {
+ padding: var(--universal-padding) !important
+ }
+}
+
+@media screen and (max-width: 767px) {
+ .hidden-sm {
+ display: none !important
+ }
+}
+
+@media screen and (min-width: 768px) and (max-width: 1279px) {
+ .hidden-md {
+ display: none !important
+ }
+}
+
+@media screen and (min-width: 1280px) {
+ .hidden-lg {
+ display: none !important
+ }
+}
+
+@media screen and (max-width: 767px) {
+ .visually-hidden-sm {
+ position: absolute !important;
+ width: 1px !important;
+ height: 1px !important;
+ margin: -1px !important;
+ border: 0 !important;
+ padding: 0 !important;
+ clip: rect(0 0 0 0) !important;
+ -webkit-clip-path: inset(100%) !important;
+ clip-path: inset(100%) !important;
+ overflow: hidden !important
+ }
+}
+
+@media screen and (min-width: 768px) and (max-width: 1279px) {
+ .visually-hidden-md {
+ position: absolute !important;
+ width: 1px !important;
+ height: 1px !important;
+ margin: -1px !important;
+ border: 0 !important;
+ padding: 0 !important;
+ clip: rect(0 0 0 0) !important;
+ -webkit-clip-path: inset(100%) !important;
+ clip-path: inset(100%) !important;
+ overflow: hidden !important
+ }
+}
+
+@media screen and (min-width: 1280px) {
+ .visually-hidden-lg {
+ position: absolute !important;
+ width: 1px !important;
+ height: 1px !important;
+ margin: -1px !important;
+ border: 0 !important;
+ padding: 0 !important;
+ clip: rect(0 0 0 0) !important;
+ -webkit-clip-path: inset(100%) !important;
+ clip-path: inset(100%) !important;
+ overflow: hidden !important
+ }
+}
\ No newline at end of file
diff --git a/resources/skins/vergilius/html_wrapper.html b/resources/skins/vergilius/html_wrapper.html
index f3b49cbaa..93474086d 100644
--- a/resources/skins/vergilius/html_wrapper.html
+++ b/resources/skins/vergilius/html_wrapper.html
@@ -2,9 +2,7 @@
-
+