@font-face {
  font-family: "Noto Sans";
  src: url("/sf/noto-sans/NotoSans-Regular.ttf") format("truetype");
}

@font-face {
  font-family: "Noto Sans";
  src: url("/sf/noto-sans/NotoSans-Bold.ttf") format("truetype");
  font-weight: bold;
}

@font-face {
  font-family: "Noto Sans";
  src: url("/sf/noto-sans/NotoSans-Italic.ttf") format("truetype");
  font-style: italic;
}

@font-face {
  font-family: "Noto Sans";
  src: url("/sf/noto-sans/NotoSans-BoldItalic.ttf") format("truetype");
  font-weight: bold;
  font-style: italic;
}

:root {
  --background-color: #fff;
  --background-accent-color: #f2f2f2;
  --text-color: #4a4a4a;
  --spacing: 1rem;
  --font-size-tiny: 9pt;
  --font-size-small: 10pt;
  --font-size-normal: 12pt;
  --font-size-large: 14pt;
  --font-size-huge: 20pt;
  --font-size-kaboom: 36pt;
  --primary-color: #4caa8d;
  --primary-accent-color: #08505e;
  --primary-contrast-color: #fff;
  --warning-color: #e70;
  --warning-contrast-color: #fff;
  --danger-color: #c1121f;
  --danger-accent-color: #c00;
  --danger-contrast-color: #fff;
  --link-color: #4caa8d;
  --link-accent-color: #2c8a6d;
  --muted-color: #999;
  --muted-contrast-color: #fff;
  --container-width: 1000px;
  --small-screen-width: 992px;
  --text-line-height: 1.75;
  --success-color: #55aa55;
  --success-contrast-color: #fff;
  --font-awesome-family: "Font Awesome 6 Pro";
  --font-awesome-light-weight: 300;
  --disabled-color: #787a95;
  --disabled-contrast-color: #b8bad5;
  --page-nav-spacing: calc(2 * var(--spacing));
  --line-width: 0.05rem;
  --border-radius: 1.2rem;
}

* {
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  margin: 0;
  padding: 0;
  color: inherit;
  text-decoration: none;
  font-style: normal;
  box-sizing: border-box;
}

html {
  background: var(--background-color);
  font-family: "Noto Sans", sans-serif;
  font-size: var(--font-size-normal);
  font-weight: inherit;
  color: var(--text-color);
}

strong {
  font-weight: bold;
}

.single-layout > footer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--spacing);
  margin-top: calc(2 * var(--spacing));
  padding: var(--spacing) 0;
  font-size: var(--font-size-tiny);
  background: var(--primary-color);
  color: var(--primary-contrast-color);
  line-height: 1.75;
}

.single-layout > footer > * {
  flex: 1;
  max-width: calc(var(--container-width) / 3);
}

.single-layout > footer ul {
  list-style-type: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

.single-layout > footer ul a {
  padding: 0 calc(0.5 * var(--spacing));
}

.single-layout > footer ul a,
.single-layout > footer ul a:hover {
  color: inherit;
}

.single-layout > footer .brand {
  display: inline-flex;
  justify-content: center;
}

.single-layout > footer .brand::before {
  mask-position: center center;
  background: var(--primary-contrast-color);
}

.single-layout > footer .author {
  text-align: right;
}

a {
  color: var(--link-color);
  cursor: pointer;
}

a:hover {
  color: var(--link-accent-color);
}

h1 {
  font-size: var(--font-size-kaboom);
  font-weight: bold;
}

h2 {
  font-size: var(--font-size-huge);
  font-weight: bold;
  letter-spacing: -0.1rem;
}

h3 {
  font-size: var(--font-size-large);
  font-weight: bold;
}

h4 {
  font-size: var(--font-size-large);
}

h1,
h2 {
  color: var(--primary-accent-color);
}

h2,
h3 {
  margin-bottom: calc(1.5 * var(--spacing));
}

h4 {
  margin-bottom: calc(1 * var(--spacing));
}

h2,
h3 {
  margin-top: calc(2.5 * var(--spacing));
}

h4 {
  margin-top: calc(1.5 * var(--spacing));
}

h1 + h2,
h2 + h3,
h3 + h4,
h2:first-child,
h3:first-child,
h4:first-child {
  margin-top: 0;
}

main p,
main ul > li,
main ol > li {
  line-height: var(--text-line-height);
}

main ul,
main ol {
  padding-left: var(--spacing);
}

p:not(:last-child),
ul:not(:last-child),
ol:not(:last-child) {
  margin-bottom: var(--spacing);
}

dl dt {
  font-weight: bold;
  margin-bottom: calc(0.5 * var(--spacing));
}

dl dt:not(:first-child) {
  margin-top: calc(1.5 * var(--spacing));
}

dl dd:not(:last-child) {
  margin-bottom: calc(0.5 * var(--spacing));
}

input[type="text"],
input[type="number"],
input[type="date"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="datetime-local"],
textarea,
select {
  background-color: var(--background-color);
  color: var(--text-color);
  padding: calc(0.5 * var(--spacing)) calc(0.7 * var(--spacing));
  border: 0.05rem solid var(--primary-color);
  border-radius: 0;
  outline-color: var(--primary-color);
  display: inline-block;
  min-width: 0;
  border-radius: var(--border-radius);
}

input[type="number"] {
  text-align: right;
}

input[type="radio"] {
  margin-right: calc(0.3 * var(--spacing));
}

button,
nav.page-navigation a,
#portal-listing-list-page .listings .listing a,
form > .actions > a,
#portal-welcome-page article a {
  display: inline-block;
  background: var(--primary-color);
  color: var(--primary-contrast-color);
  border: 0;
  width: auto;
  padding: calc(0.75 * var(--spacing)) calc(1 * var(--spacing));
  cursor: pointer;
  line-height: 1;
  border-radius: var(--border-radius);
}

button:hover,
button:focus,
nav.page-navigation a:hover,
nav.page-navigation a:focus,
#portal-listing-list-page .listings .listing a:hover,
form > .actions > :is(a:hover, a:focus),
#portal-welcome-page article a:hover {
  background: var(--primary-accent-color);
}

button:active,
nav.page-navigation a:active,
form > .actions > a:active {
  background: var(--primary-contrast-color);
  color: var(--primary-color);
}

nav.page-navigation a.delete,
form > .actions > button.delete {
  background: var(--danger-color);
  color: var(--danger-contrast-color);
}

nav.page-navigation :is(a.delete:hover, a.delete:focus),
form > .actions > :is(button.delete:hover, button.delete:focus) {
  background: var(--danger-accent-color);
}

nav.page-navigation a.delete:active,
form > .actions > button.delete:active {
  background: var(--danger-contrast-color);
  color: var(--danger-color);
}

label {
  color: var(--muted-color);
  margin-bottom: calc(0.25 * var(--spacing));
  display: block;
}

label .help {
  font-size: var(--font-size-small);
  display: block;
  font-style: italic;
}

.single-layout h1,
.single-layout h2 {
  margin-bottom: var(--spacing);
}

.single-layout header nav,
.single-layout main,
.single-layout h1 {
  max-width: var(--container-width);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}

.single-layout main,
.single-layout h1 {
  box-sizing: border-box;
}

.single-layout > header {
  padding: calc(1 * var(--spacing)) var(--spacing);
  margin-bottom: calc(2 * var(--spacing));
}

.single-layout > header > nav {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.single-layout > header ul.menu {
  list-style-type: none;
  display: flex;
}

.single-layout > header ul.menu a {
  margin: 0 var(--spacing);
  color: var(--primary-accent-color);
  border-bottom: 2px solid transparent;
  font-size: var(--font-size-large);
}

.single-layout > header ul.menu a:hover {
  border-bottom-color: var(--primary-accent-color);
}

.single-layout .brand {
  color: transparent;
  display: flex;
  align-items: center;
  text-indent: -9999rem;
  padding-top: 0.5rem;
}

.single-layout .brand::before {
  content: "";
  display: inline-block;
  width: 8rem;
  height: 8rem;
  mask-image: var(--logo-url);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: var(--logo-url);
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  background: var(--primary-color);
}

.single-layout {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.single-layout > h1 {
  order: 2;
}

.single-layout > main {
  flex: 1;
}

.single-layout > header {
  order: 1;
}

.single-layout > * {
  order: 3;
}

form {
  display: inline-flex;
  flex-direction: column;
  width: 100%;
}

form fieldset {
  border: none;
  margin-bottom: calc(1.5 * var(--spacing));
}

form fieldset > .field {
  display: inline-block;
}

form fieldset > .field > label {
  order: 1;
}

form fieldset > .field > button {
  margin-bottom: calc(1 * var(--spacing));
}

form fieldset > .field > .errorlist {
  order: 2;
  margin: 0 0 var(--spacing) 0;
}

form fieldset > br + .field {
  margin-top: var(--spacing);
}

form fieldset > .field:not(:last-child) {
  margin-right: var(--spacing);
}

form fieldset > .field > :is(input, select, textarea) {
  order: 3;
  width: auto;
}

form fieldset > .field.checkbox {
  margin-top: unset;
}

form fieldset > .field.checkbox label {
  color: inherit;
}

form fieldset > .field.checkbox label input {
  margin-right: calc(0.5 * var(--spacing));
}

fieldset legend {
  margin-bottom: var(--spacing);
  font-weight: bold;
  font-size: var(--font-size-large);
}

.success-message {
  background: var(--success-color);
  color: var(--success-contrast-color);
  padding: var(--spacing);
}

.error-message {
  background: var(--danger-color);
  color: var(--danger-contrast-color);
  padding: var(--spacing);
}

ul.errorlist {
  list-style-type: none;
  margin-bottom: var(--spacing);
  padding-left: 0;
  color: var(--danger-contrast-color);
  font-weight: bold;
}

ul.errorlist > li {
  display: inline-block;
  background: var(--danger-color);
  padding: calc(0.5 * var(--spacing)) calc(0.75 * var(--spacing));
}

nav h2 {
  display: none;
}

form > button[type="submit"] {
  margin-left: auto;
}

form > .actions {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
}

form > .actions > :is(a, button) {
  margin-left: var(--spacing);
}

table {
  border-spacing: 0;
  border-collapse: collapse;
  text-align: left;
  background: var(--background-accent-color);
  padding: 0.25rem;
  width: 100%;
  margin-bottom: var(--spacing);
}

table td,
table th {
  padding: calc(0.75 * var(--spacing)) calc(0.5 * var(--spacing));
}

table thead th,
table th[scope="col"][colspan] {
  background: var(--primary-color);
  color: var(--primary-contrast-color);
}

table th {
  font-weight: bold;
}

table tbody tr:not(:last-child) td,
table tbody tr:not(:last-child) th {
  border-bottom: 0.1rem solid var(--background-color);
}

table .number,
table .date {
  text-align: right;
}

.negative.number {
  color: var(--danger-color);
}

.pagination {
  display: flex;
  align-items: center;
  width: 100%;
  margin-top: calc(2 * var(--spacing));
  text-align: center;
  font-size: var(--font-size-small);
}

.pagination .previous-controls,
.pagination .next-controls {
  flex: 1;
}

.pagination .previous-controls {
  text-align: right;
}

.pagination .next-controls {
  text-align: left;
}

.pagination.without-previous-controls:before {
  content: "";
  flex: 1;
}

.pagination.without-next-controls:after {
  content: "";
  flex: 1;
}

.pagination a {
  display: inline-block;
  padding: calc(0.25 * var(--spacing)) calc(0.45 * var(--spacing));
  margin: 0 calc(0.25 * var(--spacing));
  border: 1px solid var(--primary-color);
}

.pagination a:hover {
  background: var(--primary-color);
  color: var(--primary-contrast-color);
}

.pagination .current {
  padding: 0 calc(0.5 * var(--spacing));
}

.htmx-request {
  position: relative;
  opacity: 0.8;
}

@keyframes htmx-indicator {
  0% {
    transform: translate(-50%, -50%) scale(1, 1);
    opacity: 1;
  }

  100% {
    transform: translate(-50%, -50%) scale(1.3, 1.3);
    opacity: 0.8;
  }
}

.htmx-request:after {
  font-family: var(--font-awesome-family);
  font-weight: var(--font-awesome-light-weight);
  content: "\f252";
  z-index: 1;
  font-size: var(--font-size-large);
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--primary-contrast-color);
  color: var(--primary-color);
  padding: var(--spacing);
  box-shadow: 0px 0px 5px rgba(0, 0, 0, 0.5);
  animation-name: htmx-indicator;
  animation-iteration-count: infinite;
  animation-duration: 0.7s;
  animation-timing-function: ease-in-out;
}

@keyframes spin {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(180deg);
  }
}

form.htmx-request button[type="submit"] {
  background-color: var(--disabled-color);
  color: var(--disabled-contrast-color);
  pointer-events: none;
}

form.htmx-request button[type="submit"]:before {
  font-family: var(--font-awesome-family);
  font-weight: var(--font-awesome-light-weight);
  content: "\f3f4";
  margin-right: calc(0.5 * var(--spacing));
  display: inline-block;
  animation-name: spin;
  animation-iteration-count: infinite;
  animation-duration: 0.7s;
  animation-timing-function: ease-in-out;
}

/* A bordered box for highlighting sections. */
.remark {
  background-color: var(--background-accent-color);
  padding: calc(0.5 * var(--spacing)) calc(1 * var(--spacing));
}

nav.page-navigation {
  display: block;
  margin-bottom: calc(1 * var(--spacing));
  padding: calc(0.75 * var(--spacing));
  background: var(--background-accent-color);
}

nav.page-navigation ul {
  list-style-type: none;
  padding: 0;
  display: inline-flex;
}

nav.page-navigation ul > li + li {
  margin-left: calc(0.75 * var(--spacing));
}

.edited-notice {
  display: block;
  background: var(--success-color);
  color: var(--success-contrast-color);
  padding: var(--spacing);
}

.edited-notice::before {
  content: "\f164";
  font-family: var(--font-awesome-family);
  font-weight: var(--font-awesome-light-weight);
  margin-right: var(--spacing);
}

#portal-listing-list-page {
  --listing-filters-width: 12rem;
}

#portal-listing-list-page h1 {
  display: none;
}

#portal-listing-list-page .category-navigation ul {
  list-style: none;
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 0;
  margin-bottom: 0;
}

#portal-listing-list-page .category-navigation ul > li {
  margin-right: calc(0.1 * var(--spacing));
}

#portal-listing-list-page .category-navigation ul > li > a {
  background: var(--background-accent-color);
  padding: calc(0.5 * var(--spacing)) calc(1 * var(--spacing));
  display: inline-block;
}

#portal-listing-list-page .category-navigation ul > li.active > a {
  background: var(--primary-color);
  color: var(--primary-contrast-color);
}

#portal-listing-list-page .category-navigation form {
  background: var(--background-accent-color);
  border-top: calc(0.5 * var(--spacing)) solid var(--primary-color);
  padding: calc(1 * var(--spacing));
}

#portal-listing-list-page .category-navigation form .controls {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: var(--spacing);
}

#portal-listing-list-page .category-navigation form .controls > * {
  margin-left: calc(1 * var(--spacing));
}

#portal-listing-list-page .category-navigation .filters {
  --filter-spacing: calc(0.5 * var(--spacing));
  display: flex;
  flex-wrap: wrap;
}

#portal-listing-list-page .category-navigation .filters label {
  display: inline-block;
  width: calc(25% - var(--filter-spacing));
  margin-right: var(--filter-spacing);
  background: var(--background-color);
  padding: calc(0.5 * var(--spacing));
  box-sizing: border-box;
}

#portal-listing-list-page .category-navigation .filters label select,
#portal-listing-list-page .category-navigation .filters label input {
  padding: calc(0.3 * var(--spacing)) 0;
  margin: 0;
  display: block;
  width: 100%;
  border: 0;
}

#portal-listing-list-page
  .category-navigation
  .filters
  :is(#id_topics, #id_usps) {
  display: none;
}

#portal-listing-list-page .listings {
  margin-top: var(--spacing);
  padding-left: calc(
    var(--with-filters) * (var(--spacing) + var(--listing-filters-width))
  );
}

#portal-listing-list-page .listings h2 {
  display: none;
}

#portal-listing-list-page .listings .listing {
  --margin: calc(3 * var(--spacing));
  --thumbnail-size: 10rem;

  margin-bottom: calc(0.5 * var(--margin));
  padding-bottom: calc(0.5 * var(--margin));
  padding-left: calc(var(--thumbnail-size) + 2 * var(--spacing));
  position: relative;
  min-height: var(--thumbnail-size);
  border-bottom: 0.05rem solid var(--primary-color);
}

#portal-listing-list-page .listings .listing::after {
  content: "";
  width: var(--thumbnail-size);
  height: var(--thumbnail-size);
  background: var(--thumbnail-url);
  background-position: center center;
  background-repeat: no-repeat;
  position: absolute;
  left: 0;
  top: 0;
}

#portal-listing-list-page .listings .listing::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--thumbnail-size);
  height: var(--thumbnail-size);
}

#portal-listing-list-page .listings .listing.without-thumbnail::before {
  background: var(--background-accent-color);
}

#portal-listing-list-page .listings .listing.without-thumbnail::after {
  background-color: none;
  background-size: 50%;
  filter: saturate(0%) brightness(0%) invert() brightness(80%);
}

#portal-listing-list-page .listings .listing.with-thumbnail::after {
  background-size: cover;
}

#portal-listing-list-page .listings .listing a {
  font-size: var(--font-size-large);
}

#portal-listing-list-page .listings .listing header {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  margin-bottom: var(--spacing);
}

#portal-listing-list-page .listings .listing header > * {
  margin: 0;
  padding: 0;
}

#portal-listing-list-page .listings .listing h3 {
  grid-row: 1;
  grid-column: 1 / 3;
  margin-bottom: calc(0.5 * var(--spacing));
}

#portal-listing-list-page .listings .listing .cme-points {
  grid-row: 2;
  grid-column: 2;
  --padding: calc(0.75 * var(--spacing));
  display: flex;
  align-items: center;
  border: 0.05rem solid var(--muted-color);
  padding-right: var(--padding);
  font-weight: bold;
}

#portal-listing-list-page .listings .listing .cme-points::before {
  content: "CME";
  display: inline-block;
  background: var(--muted-color);
  color: var(--muted-contrast-color);
  padding: calc(0.25 * var(--spacing));
  margin-right: var(--padding);
  font-weight: normal;
}

#portal-listing-list-page .listings .listing ul.usps {
  list-style: none;
  grid-row: 3;
  grid-column: 1 / 3;
  margin-top: calc(0.5 * var(--spacing));
}

#portal-listing-list-page .listings .listing ul.usps > li {
  --margin: calc(0.25 * var(--spacing));

  display: inline-block;
  padding: calc(0.5 * var(--spacing));
  line-height: 1;
  font-size: var(--font-size-small);
  background: var(--background-accent-color);
  margin-bottom: var(--margin);
  margin-right: var(--margin);
}

#portal-listing-list-page .listings .listing .subtitle {
  color: var(--muted-color);
  grid-row: 2;
  grid-column: 1;
}

#portal-listing-list-page .listing-filters {
  float: left;
  width: var(--listing-filters-width);
  margin-top: var(--spacing);
  font-size: var(--font-size-small);
  background: var(--background-accent-color);
  padding: calc(0.75 * var(--spacing));
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
}

#portal-listing-list-page .listing-filters h2 {
  display: block;
  width: 100%;
  font-size: var(--font-size-normal);
  margin-bottom: calc(0.5 * var(--spacing));
  margin-top: calc(0.5 * var(--spacing));
}

#portal-listing-list-page .listing-filters ul {
  list-style-type: none;
  padding-left: 0;
  max-height: 40vh;
  overflow-y: auto;
  overflow-x: hidden;
}

#portal-listing-list-page .listing-filters input[type="checkbox"] {
  margin-right: calc(0.5 * var(--spacing));
}

#portal-listing-list-page .listing-filters label {
  display: flex;
  align-items: flex-start;
  color: var(--text-color);
  line-height: 1;
  word-wrap: break-word;
}

#portal-listing-list-page .overview {
  margin-bottom: calc(3 * var(--spacing));
}

#portal-listing-list-page .overview h2 {
  display: none;
}

#portal-listing-list-page .overview ul {
  display: grid;
  list-style: none;
  padding: 0;
  grid-template-columns: auto auto auto;
  gap: var(--spacing);
}

#portal-listing-list-page .overview a {
  --tile-background-color: var(--primary-color);
  --tile-text-color: var(--primary-contrast-color);
  --tile-text-shadow: none;
  --tile-vertical-alignment: flex-end;
  --tile-horizontal-alignment: flex-end;

  background-color: var(--tile-background-color);
  color: var(--tile-text-color);
  text-shadow: var(--tile-text-shadow), var(--tile-text-shadow);
  position: relative;
  display: flex;
  justify-content: var(--tile-horizontal-alignment);
  align-items: var(--tile-vertical-alignment);
  padding: 0.5rem;
  flex: 1;
  height: 8rem;
  transition: 0.3s all;
  font-weight: bold;
  font-size: var(--font-size-huge);
  text-transform: uppercase;
  letter-spacing: 0.2rem;
  z-index: 2;
}

#portal-listing-list-page .overview a[data-tile-background-image] {
  background: var(--tile-background-image);
  background-position: center center;
  background-size: cover;
}

#portal-listing-list-page .overview a:hover {
  transform: scale(1.07);
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.3);
}

#portal-listing-list-page .overview a::after {
  content: "";

  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  top: 0;
  z-index: -1;

  background: linear-gradient(transparent 50%, var(--background-color) 100%);
}

#portal-privacy-policy-page {
  counter-reset: h2;
}

#portal-privacy-policy-page h2::before {
  counter-increment: h2;
  content: counter(h2) ". ";
}

.vendor-layout main {
  display: flex;
  flex-direction: row;
}

.vendor-layout .vendor-navigation {
  flex: 0 0 12rem;
  border-right: 0.05rem solid var(--background-accent-color);
  padding-right: var(--spacing);
  margin-right: var(--spacing);
  box-sizing: border-box;
}

.vendor-layout .vendor-navigation ul {
  list-style-type: none;
  padding: 0;
}

.vendor-layout .vendor-navigation li {
  padding: calc(0.5 * var(--spacing)) 0;
}

.vendor-layout .vendor-navigation a {
  display: block;
}

.vendor-layout .vendor-body {
  flex: 1;
}

.field ul.checkboxes {
  max-height: 20vh;
  overflow-y: auto;
  border: 0.05rem solid var(--primary-color);
  border-radius: var(--border-radius);
  padding: 0;
  color: var(--text-color);
  list-style-type: none;
}

.field ul.checkboxes label {
  padding: calc(0.75 * var(--spacing));
  line-height: 1;
  color: var(--text-color);
  cursor: pointer;
  margin: 0;
}

.field ul.checkboxes label {
  border-bottom: 0.05rem solid var(--background-accent-color);
}

.field ul.checkboxes label > input {
  margin-right: calc(0.25 * var(--spacing));
}

#portal-login-page form {
  align-items: center;
}

#portal-login-page form button {
  margin: 0;
}

#portal-gtc-page h2 {
  counter-reset: gtc-paragraph;
  counter-increment: gtc-h2;
}

#portal-gtc-page h2::before {
  content: counter(gtc-h2) ". ";
}

#portal-gtc-page ol {
  padding: 0;
}

#portal-gtc-page ol > li {
  counter-increment: gtc-paragraph;
  list-style-type: none;
  position: relative;
  padding-left: calc(3 * var(--spacing));
}

#portal-gtc-page ol > li::before {
  content: counter(gtc-h2) "." counter(gtc-paragraph);
  position: absolute;
  left: 0;
}

#portal-gtc-page .signature {
  max-width: 14rem;
}

#portal-blog-post-list-page article.post {
  --cover-image-size: 12rem;

  padding-left: calc(var(--cover-image-size) + var(--spacing));
  padding-bottom: calc(2 * var(--spacing));
  position: relative;
  min-height: var(--cover-image-size);
}

#portal-blog-post-list-page article.post:not(:last-child) {
  margin-bottom: calc(2 * var(--spacing));
  border-bottom: 0.1rem solid var(--background-accent-color);
}

#portal-blog-post-list-page article.post::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--cover-image-size);
  height: var(--cover-image-size);
  background: var(--cover-image);
  background-size: cover;
  background-position: center center;
}

#portal-blog-post-list-page article.post > a:last-child {
  display: block;
  text-align: right;
  font-weight: bold;
  font-size: var(--font-size-large);
}

#portal-blog-post-list-page article.post > a:last-child::after {
  font-family: var(--font-awesome-family);
  font-weight: var(--font-awesome-light-weight);
  content: "\f061";
  padding-left: var(--spacing);
}

#portal-blog-post-detail-page .intro::before {
  content: "";
  height: 8rem;
  width: 100%;
  display: inline-block;
  background: var(--cover-image);
  background-size: cover;
  background-position: center center;
  margin-bottom: var(--spacing);
}

#portal-blog-post-detail-page .intro {
  font-weight: bold;
  margin: 0 0 calc(1.5 * var(--spacing)) 0;
  line-height: 2;
}

cite .author {
  color: var(--muted-color);
}

cite .object {
  font-weight: bold;
  color: inherit;
}

.important-notice {
  background: var(--warning-color);
  padding: var(--spacing);
  color: var(--warning-contrast-color);
  display: flex;
  flex-direction: column;
}

.important-notice a {
  display: inline-block;
  font-weight: bold;
  background: var(--warning-contrast-color);
  color: var(--warning-color);
  margin-left: auto;
  padding: calc(0.5 * var(--spacing));
}

.important-notice a:hover {
  color: var(--warning-contrast-color);
  background: var(--warning-color);
}

header ul.messages {
  list-style-type: none;
  padding: 0;
  margin: 0;
  position: fixed;
  right: var(--spacing);
  top: var(--spacing);
}

header ul.messages li {
  background: var(--background-accent-color);
  color: var(--text-color);
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.3);
  padding: var(--spacing);
  width: 25rem;
  max-width: 100vw;
}

.messages .warning {
  background: var(--warning-color);
  color: var(--warning-contrast-color);
}

#portal-welcome-page {
  --image-size: 10rem;
  --section-text-color: var(--primary-color);
}

#portal-welcome-page h2 {
  text-align: center;
}

#portal-welcome-page h1 {
  font-size: var(--font-size-large);
}

#portal-welcome-page article[data-with-image] {
  position: relative;
  padding-left: calc(var(--image-size) + 1.5 * var(--spacing));
  min-height: var(--image-size);
}

#portal-welcome-page article[data-with-image] h3 {
  position: absolute;
  left: 0;
  top: 0;
  width: var(--image-size);
  height: var(--image-size);

  display: flex;
  justify-content: center;
  align-items: flex-end;

  font-size: var(--font-size-small);
  font-weight: bold;
  color: var(--section-text-color);
  padding: 0 calc(0.5 * var(--spacing));
  margin: 0;
  text-align: center;
  letter-spacing: 0.1rem;
  z-index: 1;
}

#portal-welcome-page article[data-with-image]::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--image-size);
  height: var(--image-size);
  background: var(--image);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

#portal-welcome-page article[data-with-image]::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: var(--image-size);
  height: var(--image-size);
  background: linear-gradient(transparent 60%, var(--background-color) 100%);
}

#portal-welcome-page article {
  margin-bottom: calc(2 * var(--spacing));
}

#portal-welcome-page .banners {
  --banner-height: 15rem;
  --banner-text-color: var(--text-color);

  padding: var(--spacing);
  margin: 0 0 calc(2 * var(--spacing)) 0;
  position: relative;

  display: flex;
  overflow-x: auto;
  user-select: none;
  gap: var(--spacing);

  list-style-type: none;
}

#portal-welcome-page .banners[data-with-js] {
  overflow-x: scroll;
  scrollbar-width: none;
}

#portal-welcome-page .banners[data-with-js]::-webkit-scrollbar {
  width: 0;
  height: 0;
}

#portal-welcome-page .banners li {
  width: calc(0.7 * var(--container-width));
  height: var(--banner-height);
  flex-shrink: 0;

  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  text-align: center;

  padding: 0 var(--spacing) calc(1 * var(--spacing)) var(--spacing);

  font-size: var(--font-size-huge);
  color: var(--banner-text-color);
  box-shadow: 0 0 0.5rem rgba(0, 0, 0, 0.5);
  line-height: 1.5;
}

#portal-welcome-page .banners li[data-with-logo]::before {
  --size: 5rem;

  content: "";

  width: var(--size);
  height: var(--size);
  margin-bottom: var(--spacing);

  background: var(--banner-text-color);
  mask-image: var(--banner-logo-url);
  mask-size: contain;
  mask-repeat: no-repeat;
  -webkit-mask-image: var(--banner-logo-url);
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
}

#portal-welcome-page .banners li[data-with-image] {
  background-image: var(--banner-image);
  background-size: cover;
  background-position: center center;
}

details summary {
  cursor: pointer;
  padding-bottom: calc(0.2 * var(--spacing));
}

details summary:hover {
  color: var(--link-accent-color);
}
