@charset "UTF-8";
:root {
  --text-color: #111;
  --background-color: #fbfbfb;
  --link-color: #0000ee;
  --visited-link-color: #6666ee;
  --meta-color: $grey-color;
  --highlight-r: 255;
  --highlight-g: 225; }

/* latin-ext */
@font-face {
  font-family: 'Recursive';
  font-style: normal;
  font-weight: 300 1000;
  font-display: swap;
  src: url(/fonts/recursive-latin-ext.woff2) format("woff2");
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }

/* latin */
@font-face {
  font-family: 'Recursive';
  font-style: normal;
  font-weight: 300 1000;
  font-display: swap;
  src: url(/fonts/recursive-latin.woff2) format("woff2");
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/**
 * Reset some basic elements
 */
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
hr,
dl,
dd,
ol,
ul,
figure {
  margin: 0;
  padding: 0; }

/**
 * Basic styling
 */
html {
  font-weight: 400;
  font-size: Min(1.4em, calc(0.5vw + 0.9em));
  line-height: 1.3;
  font-family: "Recursive", "Courier New", "Courier", monospace;
  color: var(--text-color);
  background-color: var(--background-color);
  -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;
  letter-spacing: 0em;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "slnt" 0, "CASL" 0.6, "CRSV" 0, "MONO" 1; }

/**
 * Set `margin-bottom` to maintain vertical rhythm
 */
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
dl,
li,
.highlight {
  margin-bottom: 1em; }

ul {
  list-style-type: none; }

ul > li {
  text-indent: -2ch; }

ol ul > li,
ul ul > li {
  padding-left: 2ch; }

ul > li:before {
  content: "- "; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 1em;
  line-height: 1.3; }

h1,
h2 {
  text-align: center;
  text-transform: uppercase;
  font-weight: 700; }

h1::before {
  content: ">> "; }

h1::after {
  content: " <<"; }

h2 {
  margin-top: 3em; }

h3 {
  margin-top: 2em;
  font-weight: 600; }

a {
  margin: -0.1rem 0;
  padding: 0.1rem 0;
  border-radius: 0.5rem 0.2rem;
  background: transparent;
  background-image: linear-gradient(to right, rgba(var(--highlight-r), var(--highlight-g), 0, 0.05), rgba(var(--highlight-r), var(--highlight-g), 0, 0.35) 4%, rgba(var(--highlight-r), var(--highlight-g), 0, 0.15));
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  text-decoration-color: rgba(10, 13, 19, 0.3); }

a:has(img) {
  background-image: none;
  padding: 0;
  margin: 0; }

a:hover {
  background-image: linear-gradient(to right, rgba(var(--highlight-r), var(--highlight-g), 0, 0.05), rgba(var(--highlight-r), var(--highlight-g), 0, 0.35) 4%, rgba(var(--highlight-r), var(--highlight-g), 0, 0.15));
  text-decoration-color: rgba(10, 13, 19, 0.1); }

a:hover:has(img) {
  background-image: none; }

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

a:visited {
  color: var(--visited-link-color); }

::selection {
  color: red;
  background: yellow; }

blockquote p:first-child {
  text-indent: -1ch; }

blockquote p:first-child:before {
  content: "“"; }

blockquote p:last-child:after {
  content: "”"; }

pre {
  overflow-x: auto;
  white-space: pre-wrap;
  white-space: -moz-pre-wrap;
  white-space: -pre-wrap;
  white-space: -o-pre-wrap;
  word-wrap: break-word; }

li.post-item {
  text-indent: -12ch;
  margin-left: 10ch; }

li.talk-item {
  margin-bottom: 2em; }

.talk-item-title {
  text-indent: -10ch;
  margin-left: 10ch;
  margin-bottom: 1lh;
  margin-top: -1lh; }

.talk-item-info {
  width: 100%;
  display: flex;
  gap: 2ch;
  margin-left: 11ch;
  justify-content: flex-start;
  align-content: stretch; }

.talk-item-info > div:has(img) {
  display: none; }

@media screen and (min-width: 115.2ch) {
  .talk-item-info > div:has(img) {
    display: block;
    min-width: 35%; }
  .talk-item-info > div img {
    padding-left: 2ch;
    width: 100%; } }

li.article-link:before,
li.book-link:before,
li.community-link:before,
li.podcast-link:before,
li.poster-link:before,
li.site-link:before,
li.slides-link:before,
li.video-link:before,
li.zine-link:before {
  display: inline-block;
  width: 2ch;
  position: relative;
  left: 1ch; }

li.article-link:before {
  content: "📄"; }

li.book-link:before {
  content: "📕"; }

li.community-link:before {
  content: "🤝"; }

li.podcast-link:before {
  content: "🎧"; }

li.poster-link:before,
li.slides-link:before {
  content: "📊"; }

li.site-link:before {
  content: "🌍"; }

li.video-link:before {
  content: "📺"; }

li.zine-link:before {
  content: "💬"; }

p.quote-source {
  text-align: right;
  margin-top: -1em; }

p.quote-source:before {
  content: "— "; }

.visually-hidden:not(:focus):not(:active) {
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
  clip: rect(1px 1px 1px 1px);
  /* IE6, IE7 */
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
  /* added line */ }

.post-meta {
  color: var(--meta-color);
  margin-bottom: 2em; }

.post-header {
  text-align: center;
  margin-bottom: 1em; }

.video {
  margin-bottom: 2em; }

.video-responsive {
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
  height: 0; }

.video-responsive iframe,
.video-responsive video {
  left: 0;
  top: 0;
  height: 100%;
  width: 100%;
  position: absolute; }

.slide {
  margin-top: 1em;
  margin-bottom: 1em; }

.slide img {
  width: 100%; }

.transcript {
  padding-bottom: 1em; }

.hero-image img {
  width: 100%; }

@media screen and (min-width: 115.2ch) {
  .inset-image {
    float: right;
    width: 45%;
    margin: 0 0 1em 3ch; } }

.inset-image {
  margin-bottom: 1em; }

.inset-image img {
  width: 100%; }

.footnote {
  text-align: center;
  width: 90%;
  margin-left: auto;
  margin-right: auto; }

.separator {
  text-align: center;
  margin: 2em auto 2em auto; }

.image-credit,
.video-caption {
  margin-bottom: 2em;
  text-align: right; }

.wrapper {
  max-width: 72ch;
  min-width: 24ch;
  margin-left: auto;
  margin-right: auto;
  padding-left: 4ch;
  padding-right: 4ch; }

.navigation {
  display: flex;
  list-style: none;
  flex-wrap: wrap;
  justify-content: center; }

.navigation li {
  padding-right: 2ch;
  white-space: nowrap;
  text-indent: 0; }

.navigation li::before {
  content: ""; }

header .wrapper {
  margin-top: 2em; }

footer .wrapper {
  margin-bottom: 2em;
  text-align: center; }

.site-heading a {
  display: block;
  text-decoration: none;
  background-image: none; }

.site-heading a,
.site-heading a:visited {
  color: var(--text-color); }

.site-heading pre {
  white-space: pre;
  margin-left: -1ch;
  width: 32ch; }

@media screen and (max-width: 50ch) {
  .site-heading pre {
    font-size: Max(0.65em, 3.5vw); } }

p.site-description {
  padding-top: 0;
  margin-top: -1em;
  padding-bottom: 1em; }

header .image-credit {
  margin-top: 0; }

pre {
  padding: 2em 2ch; }

.site-heading a {
  background-image: none; }

@media screen and (min-width: 115.2ch) {
  .site-heading {
    display: flex;
    align-items: start; }
  .site-heading a {
    margin-right: 1ch; }
  p.site-description {
    margin-top: 0;
    padding-top: 3em; } }

.links-pages {
  columns: 1; }

@media screen and (min-width: 115.2ch) {
  .links-pages {
    columns: 2; } }

.links-pages-block {
  break-inside: avoid-column; }

.links-pages .links-pages-block:first-child h3 {
  margin-top: 0; }

/**
 * Syntax highlighting styles
 */
code {
  font-family: "Recursive", "Courier New", "Courier", monospace;
  color: #666; }

.highlight {
  background: #c8c8c8; }
  .highlighter-rouge .highlight {
    background: #eef; }
  .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: #458;
    font-weight: bold; }
  .highlight .m {
    color: #099; }
  .highlight .s {
    color: #d14; }
  .highlight .na {
    color: #008080; }
  .highlight .nb {
    color: #0086b3; }
  .highlight .nc {
    color: #458;
    font-weight: bold; }
  .highlight .no {
    color: #008080; }
  .highlight .ni {
    color: #800080; }
  .highlight .ne {
    color: #900;
    font-weight: bold; }
  .highlight .nf {
    color: #900;
    font-weight: bold; }
  .highlight .nn {
    color: #555; }
  .highlight .nt {
    color: #000080; }
  .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: #d14; }
  .highlight .sc {
    color: #d14; }
  .highlight .sd {
    color: #d14; }
  .highlight .s2 {
    color: #d14; }
  .highlight .se {
    color: #d14; }
  .highlight .sh {
    color: #d14; }
  .highlight .si {
    color: #d14; }
  .highlight .sx {
    color: #d14; }
  .highlight .sr {
    color: #009926; }
  .highlight .s1 {
    color: #d14; }
  .highlight .ss {
    color: #990073; }
  .highlight .bp {
    color: #999; }
  .highlight .vc {
    color: #008080; }
  .highlight .vg {
    color: #008080; }
  .highlight .vi {
    color: #008080; }
  .highlight .il {
    color: #099; }
