@font-face {
  font-family: "PT Sans";
  src: url("/assets/fonts/PT-Sans/pt-sans_regular.woff2") format("woff2"), url("/assets/fonts/PT-Sans/pt-sans_regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "PT Sans Bold";
  src: url("/assets/fonts/PT-Sans/pt-sans_bold.woff2") format("woff2"), url("/assets/fonts/PT-Sans/pt-sans_bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "PT Sans Italic";
  src: url("/assets/fonts/PT-Sans/pt-sans_italic.woff2") format("woff2"), url("/assets/fonts/PT-Sans/pt-sans_italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "PT Sans Bold Italic";
  src: url("/assets/fonts/PT-Sans/pt-sans_bold-italic.woff2") format("woff2"), url("/assets/fonts/PT-Sans/pt-sans_bold-italic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}
/**
 * Basic styling
 */
:root {
  color-scheme: dark;
}

body {
  font: 400 20px/1.5 "PT Sans", sans-serif;
  color: #cafffa;
  background-color: #111;
  background-image: url(/assets/misc/starry-night512.gif);
  -webkit-text-size-adjust: 100%;
  -webkit-font-feature-settings: "kern" 1;
  -moz-font-feature-settings: "kern" 1;
  -o-font-feature-settings: "kern" 1;
  font-feature-settings: "kern" 1;
  font-kerning: normal;
  margin: 0;
}

/**
 * Links
 */
a {
  color: #b3d4f0;
}
a:hover {
  color: #cafffa;
  text-decoration: underline;
}

.pretty-button,
.card {
  padding: 5px 10px;
  text-decoration: none;
  color: #b3d4f0;
  background: linear-gradient(135deg, #1e1e1e, #2d2d2d);
  border: 3px double #b3d4f0;
  box-shadow: 0 0 8px #b3d4f0;
  text-shadow: 0 0 5px #b3d4f0;
  margin-bottom: 1em;
  transition: all 0.3s;
  border-radius: 10px;
}
.pretty-button:hover,
.card:hover {
  background: linear-gradient(135deg, #2d2d2d, #1e1e1e);
  color: #e1f0fc;
  box-shadow: 0 0 15px #b3d4f0;
}

h1 {
  text-wrap: balance;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  text-shadow: 0 0 8px #1c4971;
}

h1,
h2,
.header-band {
  background: linear-gradient(to right, #b3d4f0 50%, #7ac2ff 70%, rgba(0, 110, 203, 0) 100%);
  line-height: 1em;
  margin-left: -15em;
  padding-left: 15em;
  padding-top: 5px;
  padding-bottom: 5px;
  width: 100%;
  color: #13222f;
  text-shadow: 0 0 12px #2d93ec;
}
h1 a,
h1 span,
h2 a,
h2 span,
.header-band a,
.header-band span {
  display: block;
  width: 75%;
  color: inherit;
  text-align: left;
}
@media screen and (max-width: 800px) {
  h1 a,
  h1 span,
  h2 a,
  h2 span,
  .header-band a,
  .header-band span {
    width: unset;
  }
}

p {
  margin-block-start: 0.75em;
  margin-block-end: 0.75em;
}

/**
 * `main` element
 */
main {
  display: block;
}

/**
 * Images
 */
img {
  display: block;
  margin-left: auto;
  margin-right: auto;
  max-width: 60%;
}
@media screen and (max-width: 800px) {
  img {
    max-width: 45%;
  }
}

div video {
  display: block;
  max-width: 60%;
  margin-left: auto;
  margin-right: auto;
  height: auto;
}

/**
 * Figures
 */
figure > img {
  display: block;
}

figcaption {
  font-size: 17.5px;
  text-align: center;
  font-style: italic;
}

/**
 * Lists
 */
ul,
ol {
  padding-left: 1.25em;
}

li > ul,
li > ol {
  margin-bottom: 0;
}

/**
 * Blockquotes
 */
blockquote {
  color: #808080;
  border-left: 4px solid #aeaeae;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  font-size: 1.1em;
  padding-left: 1em;
  font-style: italic;
}
blockquote > :last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 800px) {
  blockquote {
    margin: 0;
  }
}

/**
 * Code formatting
 */
pre,
code {
  font-size: 0.9375em;
  border: 1px solid #aeaeae;
  border-radius: 3px;
  background-color: #444;
}

code {
  padding: 1px 5px;
}

pre {
  padding: 8px 12px;
  overflow-x: auto;
}
pre > code {
  border: 0;
  padding-right: 0;
  padding-left: 0;
}

textarea {
  border-radius: 4px;
  background-color: #444;
}

/**
 * Clearfix
 */
/**
 * Icons
 */
.icon {
  image-rendering: pixelated;
  width: 16px;
  height: 16px;
  padding-right: 5px;
  display: inline-block;
}

.flat-icon {
  filter: invert(100%) sepia(5%) saturate(0%) hue-rotate(328deg) brightness(104%) contrast(100%);
}

/**
 * Tables
 */
table {
  width: 100%;
  text-align: center;
  border-collapse: collapse;
  border: 3px double #b3d4f0;
  box-shadow: 0 0 10px #b3d4f0;
  border-radius: 10px;
}
table thead,
table th {
  background: linear-gradient(to bottom, #36414b 50%, rgb(49, 78, 105) 100%);
  text-shadow: 0 0 6px #2d93ec;
  font-size: 1.2em;
}
table thead tr,
table th tr {
  background: none;
}
table thead tr td,
table th tr td {
  padding: 0.5em 0;
}
table tr {
  background-color: #222;
}
table tr:nth-child(even) {
  background-color: #444;
}
table td {
  border: 1px solid #b3d4f0;
}
table td.column-icon {
  width: 10%;
}
table td .icon {
  width: 32px;
  height: 32px;
  vertical-align: bottom;
}

/**
 * Text effects
 */
.text-focus {
  text-align: center;
}

.divider {
  display: flex;
  align-items: center;
  color: #bbb;
  font-style: italic;
}
.divider:before, .divider:after {
  content: "";
  height: 1px;
  background-color: #ccc;
  flex-grow: 1;
}
.divider:before {
  margin-right: 5%;
}
.divider:after {
  margin-left: 5%;
}

/**
 * Site header
 */
.site-header {
  position: fixed;
  left: 0;
  top: 0;
  height: 100%;
  width: 200px;
  border-right: solid #b3d4f0 4px;
}
@media screen and (max-width: 800px) {
  .site-header {
    height: 50px;
    width: 100%;
  }
}

.page-title {
  border: solid black 1px;
  background: none;
  background-color: #272727;
  font-size: 1.8em;
  color: #cafffa;
  margin: 0;
  padding-left: 0;
  text-align: center;
  justify-content: center;
}
@media screen and (max-width: 800px) {
  .page-title {
    display: none;
  }
}

.site-nav {
  background-color: #222;
  position: relative;
  height: 100%;
}
@media screen and (max-width: 800px) {
  .site-nav {
    overflow-x: scroll;
    overflow-y: hidden;
    white-space: nowrap;
    width: calc(100vw - 18px);
    height: auto;
    padding-right: 18px;
  }
  .site-nav .header-item {
    display: inline-block;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
    transition-property: background, box-shadow;
  }
  .site-nav .divider {
    display: inline-flex;
    vertical-align: top;
    padding: 0 1em;
  }
  .site-nav .divider:before, .site-nav .divider:after {
    width: 2em;
  }
}

.header-item {
  display: block;
  width: auto;
  padding: 5px 10px;
  text-decoration: none;
  color: #b3d4f0;
  margin-bottom: 8px;
  transition: all 0.3s;
  border-radius: 10px;
}
.header-item:hover {
  background: linear-gradient(135deg, #2d2d2d, #1e1e1e);
  color: #e1f0fc;
  box-shadow: 0 0 15px #b3d4f0;
}
@media screen and (max-width: 800px) {
  .header-item {
    border: 3px double #b3d4f0;
    background: linear-gradient(135deg, #1e1e1e, #2d2d2d);
    box-shadow: 0 0 10px #b3d4f0;
    text-shadow: 0 0 5px #b3d4f0;
  }
}

/**
 * Site footer
 */
body .button-row {
  text-align: center;
  margin-left: 200px;
}
@media screen and (max-width: 800px) {
  body .button-row {
    margin-left: 0;
  }
}

.button-row {
  text-align: center;
  list-style: none;
}
@media screen and (max-width: 800px) {
  .button-row {
    text-align: unset;
  }
}

.button-row a {
  display: inline-block;
}

.button-row a img {
  max-width: 100%;
}
@media screen and (max-width: 800px) {
  .button-row a img {
    width: 200%;
  }
}

.site-footer {
  margin-left: 200px;
  width: auto;
  text-align: center;
  display: flex;
  justify-content: space-evenly;
  flex-wrap: wrap;
}
@media screen and (max-width: 800px) {
  .site-footer {
    margin: 0;
  }
}

.footer-item {
  display: inline-block;
}
.footer-item .icon {
  padding: 0;
  width: 32px;
  height: 32px;
  vertical-align: middle;
}

.footer-heading {
  font-size: 1.125em;
}

.footer-bar {
  padding: 0;
  text-align: center;
  list-style: none;
}
.footer-bar li {
  margin: 0.5em;
  display: inline-block;
}
.footer-bar li a {
  text-decoration: none;
}
.footer-bar li a:hover {
  text-decoration: underline;
}

/**
 * Page content
 */
.page-content {
  margin-left: 200px;
  width: auto;
  border-style: none solid;
  border-color: black;
  border-width: 1px;
  padding: 1em;
}
@media screen and (max-width: 800px) {
  .page-content {
    margin-left: 0;
    padding-top: 50px;
  }
}
@media screen and (max-width: 800px) {
  .page-content {
    width: auto;
  }
}

.content-wrapper {
  margin: auto;
  max-width: 50em;
  padding-right: 5em;
  padding-left: 1em;
}
@media screen and (max-width: 800px) {
  .content-wrapper {
    padding: unset;
  }
}

.post-list-heading {
  font-size: 1.75em;
  text-align: center;
  line-height: normal;
}

.post-list {
  margin-left: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 1em;
}
@media screen and (max-width: 800px) {
  .post-list {
    padding: 0;
    display: block;
  }
}
.post-list li {
  padding: 0.1em;
  background-color: #222;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  text-shadow: 0 0 1px #b3d4f0;
  min-width: 40%;
  flex: 1;
}
@media screen and (max-width: 800px) {
  .post-list li {
    padding: 0;
  }
}
.post-list > li > a {
  font-size: 1.4em;
  font-weight: bold;
}
.post-list img {
  max-width: 100%;
  height: auto;
}

.post-item.card .topics {
  margin-bottom: 5px;
}
.post-item.card .topics a {
  box-shadow: 0 0 3px #b3d4f0;
}

.card-image {
  height: auto;
  max-width: 20vw;
  margin-top: auto;
}
@media screen and (max-width: 800px) {
  .card-image {
    width: 90%;
    max-width: 90%;
  }
}

.post-meta-simple,
.post-meta,
.post-meta-card {
  font-size: 17.5px;
  color: #aeaeae;
  margin: 0;
  margin-top: -0.75em;
}

.post-meta-simple,
.post-meta-card {
  margin-top: unset;
}

.post-description {
  font-size: 1.2em;
  font-style: italic;
}

.post-link {
  display: block;
  font-size: 1.5em;
}

.post-link > p {
  margin: 0;
}

/**
 * Blog index
 */
.tagcloud {
  margin: 0.5em;
  margin-bottom: 1em;
  padding: 0;
  text-align: center;
  list-style: none;
}
.tagcloud li {
  display: inline-block;
  margin-top: 1em;
}
.tagcloud li a .icon {
  padding: 0;
  height: 32px;
  width: 32px;
  vertical-align: middle;
}

.topic-item {
  font-size: 0.65em;
}
.topic-item .icon {
  vertical-align: middle;
  padding-right: 0;
}

.rss-subscribe-list a {
  display: block;
}

.tag {
  color: white;
  padding-left: 0.5em;
  padding-right: 0.5em;
  border-radius: 1em;
}

.green {
  background-color: green;
}

.blue {
  background-color: mediumblue;
}

/**
 * Posts
 */
.post {
  max-width: inherit;
}
.post figure {
  margin-block-start: 0.75em;
  margin-block-end: 0.75em;
  margin: auto;
}
.post p img,
.post figure img {
  max-width: 100%;
  width: auto;
  height: 100%;
}

.post-header {
  margin-bottom: 20px;
}

.post-title {
  font-size: 2.625em;
  line-height: 1;
  text-align: center;
  font-weight: bold;
  margin-top: -20px;
  margin-left: -50vw;
  margin-bottom: 0.1em;
  padding-left: 50vw;
  background: linear-gradient(to right, #b3d4f0 50%, #7ac2ff 80%, rgba(0, 110, 203, 0) 100%);
}
@media screen and (max-width: 800px) {
  .post-title {
    margin-top: 0;
  }
}

.post-content h2 {
  font-size: 2em;
}
@media screen and (max-width: 800px) {
  .post-content h2 {
    font-size: 1.75em;
  }
}
.post-content h3 {
  font-size: 1.625em;
  margin: 0;
}
@media screen and (max-width: 800px) {
  .post-content h3 {
    font-size: 1.375em;
  }
}
.post-content h4 {
  font-size: 1.25em;
  margin: 0;
}
@media screen and (max-width: 800px) {
  .post-content h4 {
    font-size: 1.125em;
  }
}

/**
 * Project page
 */
.project-title {
  margin: 0.25em;
}
.project-title .icon {
  width: 32px;
  height: 32px;
  vertical-align: sub;
}

.project-status {
  margin: 0.25em 0;
  margin-right: -10px;
  padding-right: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 800px) {
  .project-status {
    padding-left: 10%;
    justify-content: space-between;
  }
}
.project-status:before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  width: 16px;
  height: 16px;
  image-rendering: pixelated;
  background-position: center;
  background-size: contain;
  margin: 0 6px 0 0;
  padding: 3px;
  border-radius: 4px;
}

.card:has(.project-title) {
  pointer-events: none;
}
.card:has(.project-title) * a {
  pointer-events: all;
}

.project-links,
.project-status,
.project-description {
  text-shadow: none;
}

.card-active {
  border-color: #b6ffb6;
  box-shadow: 0 0 10px #b6ffb6;
}
.card-active .project-status:before {
  background-image: url("/assets/silk/lightning.png");
}
.card-active .project-status {
  color: #093b09;
  background: linear-gradient(to left, #b0f3b0 50%, #349737 85%, rgba(0, 0, 0, 0) 100%);
  text-shadow: 0 0 5px #00ff00;
}
.card-active:hover {
  box-shadow: 0 0 15px #b6ffb6;
}

.card-inactive {
  border-color: #ffe1ad;
  box-shadow: 0 0 10px #ffe1ad;
}
.card-inactive .project-status:before {
  background-image: url("/assets/silk/hourglass_delete.png");
}
.card-inactive .project-status {
  color: #143014;
  background: linear-gradient(to left, #ffe1ad 50%, #ffd58e 85%, rgba(0, 0, 0, 0) 100%);
  text-shadow: 0 0 5px #ffa200;
}
.card-inactive:hover {
  box-shadow: 0 0 15px #ffe1ad;
}

.card-complete {
  border-color: #b3d4f0;
  box-shadow: 0 0 10px #b3d4f0;
}
.card-complete .project-status:before {
  background-image: url("/assets/silk/tick.png");
}
.card-complete .project-status {
  color: #13222f;
  background: linear-gradient(to left, #b3d4f0 50%, #7ac2ff 85%, rgba(0, 110, 203, 0) 100%);
  text-shadow: 0 0 5px #2d93ec;
}
.card-complete:hover {
  box-shadow: 0 0 15px #2d93ec;
}

/**
 * Contact page
 */
.contact-avatar {
  padding-left: 2em;
  float: right;
}
@media screen and (max-width: 800px) {
  .contact-avatar {
    float: none;
    padding: 0;
  }
}
.contact-avatar img {
  border-radius: 5px;
  max-width: fit-content;
}
@media screen and (max-width: 800px) {
  .contact-avatar img {
    width: 30%;
  }
}

.contact-accounts {
  list-style: none;
}
.contact-accounts img {
  image-rendering: auto;
}

/**
 * Tag filter page
 */
.tag-description h1 .icon {
  width: unset;
  height: 0.8em;
  vertical-align: baseline;
}
.tag-description p {
  margin-top: 0;
}

.tag-filter-links p {
  margin-bottom: 0;
}
.tag-filter-links ul {
  margin-top: 0;
  list-style: none;
  position: relative;
  left: -1em;
}

.tag-filter-tagclouds p {
  margin-bottom: -0.3em;
}
.tag-filter-tagclouds ul {
  margin-top: 0;
}

/**
 * Callouts
 * A remake of the Obsidian feature https://help.obsidian.md/Editing+and+formatting/Callouts
 */
.callout {
  overflow: hidden;
  border-style: solid;
  border-width: 3px;
  border-radius: 4px;
  width: 50%;
  margin: 1em auto;
  background-color: #29446c;
  padding: 12px 12px 12px 24px;
}
@media screen and (max-width: 800px) {
  .callout {
    width: 80%;
  }
}

.callout-title {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  font-size: 1.5em;
  color: var(--callout-title-color);
}

.callout-icon {
  width: 32px;
  height: 32px;
  margin: 0;
}

.callout-title-inner {
  font-weight: bold;
}

.callout-content {
  overflow-x: auto;
  padding: 0;
}
.callout-content p {
  margin-block-start: 1rem;
  margin-block-end: 1rem;
}

.callout-note {
  background-color: rgba(27, 42, 53, 0.95);
  border-color: #cea476;
  --callout-title-color: #ffe88c;
}

.callout-info {
  background-color: rgba(27, 42, 53, 0.95);
  border-color: #a2bddd;
  --callout-title-color: #9bcdff;
}

.callout-summary {
  background-color: #1b2a2a;
  border-color: #d4e6fd;
  --callout-title-color: #53dfdd;
}

.callout-todo {
  background-color: rgba(27, 42, 53, 0.95);
  border-color: #cea476;
  --callout-title-color: #f6df80;
}

.callout-tip {
  background-color: #04403f;
  border-color: #fcf0c4;
  --callout-title-color: #f6df80;
}

.callout-success {
  background-color: #0f330f;
  border-color: #90d284;
  --callout-title-color: #82cb78;
}

.callout-question {
  background-color: #4a4f54;
  border-color: #d0deee;
  --callout-title-color: #9bcdff;
}

.callout-warning {
  background-color: #451602;
  border-color: #e9973f;
  --callout-title-color: #e9973f;
}

.callout-failure {
  background-color: #521618;
  border-color: #ff585b;
  --callout-title-color: #ff7b7e;
}

.callout-danger {
  background-color: #521618;
  border-color: #eb6e5a;
  --callout-title-color: #ff7b7e;
}

.callout-bug {
  background-color: #521618;
  border-color: #eb6e5a;
  --callout-title-color: #ff7b7e;
}

.callout-example {
  background-color: #382b58;
  border-color: #a882ff;
  --callout-title-color: #a882ff;
}

.callout-quote {
  background-color: #3b3f43;
  border-color: #5d8bb3;
  --callout-title-color: #7c7c7c;
}

.big {
  font-size: 1.5em;
}

/**
 * Syntax highlighting styles
 */
.highlight {
  background: #444;
}
.highlighter-rouge .highlight {
  background: #444;
}
.highlight .c {
  color: #998;
  font-style: italic;
}
.highlight .err {
  color: #a61717;
  background-color: #e3d2d2;
}
.highlight .k {
  font-weight: bold;
}
.highlight .o {
  font-weight: bold;
}
.highlight .cm {
  color: #998;
  font-style: italic;
}
.highlight .cp {
  color: #999;
  font-weight: bold;
}
.highlight .c1 {
  color: #998;
  font-style: italic;
}
.highlight .cs {
  color: #999;
  font-weight: bold;
  font-style: italic;
}
.highlight .gd {
  color: #000;
  background-color: #fdd;
}
.highlight .gd .x {
  color: #000;
  background-color: #faa;
}
.highlight .ge {
  font-style: italic;
}
.highlight .gr {
  color: #a00;
}
.highlight .gh {
  color: #999;
}
.highlight .gi {
  color: #000;
  background-color: #dfd;
}
.highlight .gi .x {
  color: #000;
  background-color: #afa;
}
.highlight .go {
  color: #888;
}
.highlight .gp {
  color: #555;
}
.highlight .gs {
  font-weight: bold;
}
.highlight .gu {
  color: #aaa;
}
.highlight .gt {
  color: #a00;
}
.highlight .kc {
  font-weight: bold;
}
.highlight .kd {
  font-weight: bold;
}
.highlight .kp {
  font-weight: bold;
}
.highlight .kr {
  font-weight: bold;
}
.highlight .kt {
  color: #799bff;
  font-weight: bold;
}
.highlight .m {
  color: #1cdbdb;
}
.highlight .s {
  color: #e1abb8;
}
.highlight .na {
  color: #13debb;
}
.highlight .nb {
  color: #79bdf6;
}
.highlight .nc {
  color: #799bff;
  font-weight: bold;
}
.highlight .no {
  color: #008080;
}
.highlight .ni {
  color: #800080;
}
.highlight .ne {
  color: #900;
  font-weight: bold;
}
.highlight .nf {
  color: #f9a1a1;
  font-weight: bold;
}
.highlight .nn {
  color: #555;
}
.highlight .nt {
  color: #b7b7ff;
}
.highlight .nv {
  color: #008080;
}
.highlight .ow {
  font-weight: bold;
}
.highlight .w {
  color: #bbb;
}
.highlight .mf {
  color: #099;
}
.highlight .mh {
  color: #099;
}
.highlight .mi {
  color: #099;
}
.highlight .mo {
  color: #099;
}
.highlight .sb {
  color: #ffb3ee;
}
.highlight .sc {
  color: #ffb3ee;
}
.highlight .sd {
  color: #ffb3ee;
}
.highlight .s2 {
  color: #ffb3ee;
}
.highlight .se {
  color: #ffb3ee;
}
.highlight .sh {
  color: #ffb3ee;
}
.highlight .si {
  color: #ffb3ee;
}
.highlight .sx {
  color: #ffb3ee;
}
.highlight .sr {
  color: #009926;
}
.highlight .s1 {
  color: #ffb3ee;
}
.highlight .ss {
  color: #990073;
}
.highlight .bp {
  color: #999;
}
.highlight .vc {
  color: #008080;
}
.highlight .vg {
  color: #008080;
}
.highlight .vi {
  color: #008080;
}
.highlight .il {
  color: #099;
}

/*# sourceMappingURL=main.css.map */