@font-face {
  font-family: "Karla";
  src: local("Karla Regular"), local("Karla-Regular"), url("./fonts/Karla/static/Karla-Regular.ttf") format("truetype");
}

@font-face {
  font-family: "Karla";
  src: local("Karla Bold"), local("Karla-Bold"), url("./fonts/Karla/static/Karla-Bold.ttf") format("truetype");
  font-weight: bold;
}

:root {
  --font: "Karla", sans-serif;
  --color-background: #f1f1f4;
  --color-accent: oklch(0.5 0.14 314.67 / 1);
  --color-text: #222;
  --color-text-secondary: rgba(0, 0, 0, 0.4);
  --color-wash: rgba(0, 0, 0, 0.03);
  --color-wash-active: rgba(0, 0, 0, 0.05);
  --color-link: var(--color-accent);
  --color-border: rgba(0, 0, 0, 0.15);
  --color-underline: var(--color-border);
  --color-border-dark: var(--color-text);
  --u: .25rem;
  --u2: calc(var(--u) * 2);
  --u3: calc(var(--u) * 3);
  --u4: calc(var(--u) * 4);
  --u5: calc(var(--u) * 5);
  --u6: calc(var(--u) * 6);
  --u7: calc(var(--u) * 7);
  --u8: calc(var(--u) * 8);
  --u10: calc(var(--u) * 10);
  --u12: calc(var(--u) * 12);
  --measure: 40rem;
  --type: calc(var(--u) * 5);
  --line: calc(var(--u) * 8);
  --type-sm: calc(var(--u) * 4);
  --line-sm: var(--line);
  --para: var(--type);
  --h1: var(--type);
  --line-h1: var(--line);
  --type-xl: var(--type);
  --line-xl: var(--line);
  --radius: var(--u3);
  --pad: var(--line);
  --g12: repeat(12, 1fr);
  --border: 1px solid var(--color-border);
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  text-align: left;
  list-style: none;
}

a {
  color: var(--color-link);
  text-decoration-color: var(--color-underline);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
}

th {
  font-weight: normal;
}

.font {
  font-family: var(--font);
}

.font-serif {
  font-family: var(--font-serif);
}

.type {
  font-size: var(--type);
  line-height: var(--line);  
}

.type-sm {
  font-size: var(--type-sm);
  line-height: var(--line-sm);
}

.type-xl {
  font-size: var(--type-xl);
  line-height: var(--line-xl);
}

.h1 {
  font-size: var(--h1);
  line-height: var(--line-h1);
  font-weight: bold;
}

.h2 {
  font-size: var(--type);
  line-height: var(--line);
  font-weight: bold;
}

.label {
  font-weight: bold;
  color: var(--color-text-secondary);
  font-size: var(--type-sm);
  line-height: var(--line);
  text-transform: uppercase;
}

.bold {
  font-weight: bold;
}

.italic {
  font-style: italic;
}

.capitalize {
  text-transform: capitalize;
}

.text-align-right {
  text-align: right;
}

.no-dec {
  text-decoration: none;
}

.trunc {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.bg {
  background: var(--color-background);
  color: var(--color-text);
}

.color-text {
  color: var(--color-text);
}

.color-secondary {
  color: var(--color-text-secondary);
}

.flex {
  display: flex;
  justify-content: stretch;
}

.colgap {
  grid-column-gap: var(--pad);
}

.gkv {
  display: grid;
  grid-template-columns: var(--g12);
  grid-column-gap: var(--pad);
}

.gkv-key {
  grid-column: 1 / 4;
}

.gkv-value {
  grid-column: 4 / 13;
}

.page {
  background-color: var(--color-background);
  color: var(--color-text);
}

.page-content {
  padding: var(--pad);
}

.flex-item {
  flex-grow: 1;
  flex-shrink: 1;
}

.pad {
  padding: var(--pad);
}

.pad-x {
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.pad-y {
  padding-top: var(--pad);
  padding-bottom: var(--pad);
}

.pad-t {
  padding-top: var(--pad);
}

.pad-b {
  padding-bottom: var(--pad);
}

.pad-page {
  padding: calc(var(--u) * 40) 0;
}

.pad-hero {
  padding: calc(var(--u) * 24) 0;
}

.nav {
  display: flex;
  list-style: none;
  gap: var(--pad);
}

.nav > ul {
  display: flex;
  list-style: none;
  gap: var(--pad);
}

.nav-end {
  margin-left: auto;
}

.list-inline {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}

.list-inline > li {
  display: inline-block;
}

.list-inline > li:not(:last-child)::after {
  content: "•";
  display: inline-block;
  padding: 0 var(--u2);
  color: var(--color-text-secondary);
}

.block {
  display: block;
}

.button {
  border-radius: var(--radius);
  display: inline-block;
  padding: var(--u) var(--u2);
  white-space: nowrap;
}

.scroll-x {
  width: 100%;
  overflow-y: hidden;
  overflow-x: auto;
}

.row {
  border-top: var(--border);
  padding: var(--u4) 0;
}

.row-thick {
  border-top: 4px solid var(--color-border);
  padding: var(--u4) 0;
}

.container {
  max-width: var(--measure);
  margin-left: auto;
  margin-right: auto;
}

.content {
  display: grid;
  grid-template-columns:
    1fr
    min(var(--measure), 100%)
    1fr;
  row-gap: var(--para);
}

.content > * {
  grid-column: 2;
}

.content > .full {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.content > :is(h1, h2, h3, h4, h5, h6):not(:last-child) {
  color: var(--color-text-secondary);
  font-family: var(--font);
  font-size: var(--type-sm);
  font-weight: bold;
  text-transform: uppercase;
  line-height: var(--line);
  padding-top: calc(var(--u) * 6);
}

.content :is(img, video, picture) {
  display: block;
  max-width: 100%;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  margin-left: auto;
  margin-right: auto;
}

.content :where(ul, ol) {
  display: grid;
  grid-template-columns: 1fr;
  grid-row-gap: var(--u);
}

.content :where(ul, ol) li {
  padding-left: var(--line);
  position: relative;
}

.content :where(ul, ol) li::before {
  content: '-';
  color: var(--color-text-secondary);
  display: block;
  position: absolute;
  width: var(--line);
  left: 0;
}

.content .transclude {
  padding-top: var(--u3);
  padding-bottom: var(--u3);
}

.content .transclude + .transclude {
  padding-top: 0;
}

.content blockquote {
  border: 0.5px solid var(--color-border);
  border-radius: var(--radius);
  font-family: var(--font);
  padding: var(--u4) var(--pad);
  display: grid;
  grid-template-columns: 1fr;
  row-gap: var(--u2);
}

.content > hr {
  background-color: var(--color-border);
  border-radius: var(--u);
  border: 0;
  display: block;
  height: 2px;
  margin: calc(var(--u) * 6) 0;
}

.content figcaption {
  padding-top: calc(var(--line) / 2);
  color: var(--color-text-secondary);
  font-size: var(--type-sm);
  line-height: var(--line);
}

.content table {
  font-size: var(--type-sm);
  line-height: var(--line);
  border: 1px solid var(--color-border);
  border-collapse: collapse;
  width: 100%;
}

.content table caption {
  font-weight: bold;
  border: 1px solid var(--color-border);
  border-bottom: 0;
  padding: var(--u) var(--u2);
  text-align: left;
}

.content table th {
  font-weight: bold;
}

.content table th,
.content table td {
  border: 1px solid var(--color-border);
  padding: var(--u) var(--u2);
}

.transclude {
  font-family: var(--font);
  font-size: var(--type);
  line-height: var(--line);
}

.transclude > .transclude-link {
  background-color: var(--color-wash);
  border-radius: var(--radius);
  display: block;
  color: inherit;
  text-decoration: none;
  padding: var(--u4) var(--pad);
  transition: background-color 500ms ease-out;
  overflow: hidden;
}

.transclude > .transclude-link:is(:hover, :active) {
  background-color: var(--color-wash-active);
}

.transclude-plain > .transclude-link {
  background-color: transparent;
  border-radius: 0;
}

.transclude-link:hover {
  border-color: var(--color-border-dark);
}

.transclude-title {
  color: var(--color-text);
  font-weight: bold;
}

.transclude-summary {
  color: var(--color-text-secondary);
  margin: 0;
}

.content > .transclude:has(+ .transclude) {
  margin-bottom: var(--u2);
}

.wikilink {
  font-weight: bold;
}

.article-header {
  padding-bottom: var(--line);
}

.meta-title {
  padding-bottom: var(--u);
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.meta-main {
  background-color: var(--color-wash);
  border-radius: var(--radius);
  overflow: hidden;
}

.meta-pad {
  padding: var(--pad);
}

.meta-row:not(:last-child) {
  border-bottom: 0.5px solid var(--color-border);
}

@media screen and (max-width: 600px) {
  .page-content {
    padding: var(--u4);
  }

  .gkv {
    display: block;
  }
}