:root {
  accent-color: #d0a3e2;
  font-family: "RecursiveVariable", sans-serif;
  font-variation-settings: "MONO" 0, "CASL" 1, "CRSV" 1, "slnt" -5;
  font-weight: 350;
  line-height: 1.5;
}

a {
  text-decoration: none;
}
a:link {
  color: #d0a3e2;
  font-weight: bolder;
}
a:visited {
  color: #a17eaf;
}

dialog {
  border: ridge 5px;
  max-inline-size: 90ch;
}

html {
  scrollbar-color: #d0a3e2 Canvas;
  background: radial-gradient(rgb(255, 255, 255) 30%, transparent 30%), radial-gradient(rgb(255, 255, 255) 30%, transparent 30%), radial-gradient(rgb(0, 0, 0) 30%, transparent 30%), radial-gradient(rgb(0, 0, 0) 30%, transparent 30%);
  background-position: 0px 0px, 124px 124px, -12.4px 12.4px, 111.6px 136.4px;
  background-size: 248px 248px;
  background-color: #d0a3e2;
}

:focus-visible {
  outline-color: #d0a3e2;
}

::selection {
  background-color: #d0a3e2;
}

::marker {
  color: #d0a3e2;
}

:is(::-webkit-calendar-picker-indicator,
::-webkit-clear-button,
::-webkit-inner-spin-button,
::-webkit-outer-spin-button) {
  color: #d0a3e2;
}

details summary {
  cursor: pointer;
}
details summary *:first-child {
  display: inline;
}

.content {
  background-color: #ffffff;
}
.content main hr {
  inline-size: 50%;
  float: none;
  margin-top: 1em;
  margin-bottom: 1em;
}

.button,
input[type=radio] ~ .filters label {
  color: inherit !important;
  font-weight: inherit !important;
  background-color: #cecece;
  height: 4em;
  padding: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border: outset 2px;
  text-decoration: none;
  border-color: #dedede #000 #000 #dedede;
}
.button[for=explicit],
input[type=radio] ~ .filters label[for=explicit] {
  background-color: #fecece;
}
.button[for=questionable],
input[type=radio] ~ .filters label[for=questionable] {
  background-color: #fefece;
}
.button[for=everyone],
input[type=radio] ~ .filters label[for=everyone] {
  background-color: #cefece;
}

.button {
  height: 2em;
}

.button.current,
input[type=radio][id=all]:checked ~ .filters [for=all] {
  background-color: #9b9b9b;
  border: inset 2px;
}

img.eightyeight {
  height: 31px;
  width: 88px;
  aspect-ratio: 88/31;
  image-rendering: pixelated;
}

input[type=radio][id=explicit]:checked ~ .filters [for=explicit] {
  background-color: #cb9b9b;
  border: inset 2px;
}

input[type=radio][id=questionable]:checked ~ .filters [for=questionable] {
  background-color: #cbcb9b;
  border: inset 2px;
}

input[type=radio][id=everyone]:checked ~ .filters [for=everyone] {
  background-color: #9bcb9b;
  border: inset 2px;
}

span.spoiler {
  background-color: black;
  color: transparent;
  cursor: help;
  user-select: none;
  transition: background 0.3s ease 0.2s, color 0.2s, ease 0.25s;
}
span.spoiler:hover, span.spoiler:focus {
  background-color: hsl(283, 52%, 90%);
  color: inherit;
}

em {
  font-variation-settings: "MONO" 0, "CASL" 1, "CRSV" 1, "slnt" -15;
  font-weight: 600;
}

strong {
  font-variation-settings: "MONO" 0, "CASL" 1, "CRSV" 1, "slnt" 0;
  font-weight: 800;
}

h1,
h2,
h3 {
  margin: 0;
}

h1 {
  font-size: 4.235801032rem;
}

h2 {
  font-size: 2.617924rem;
  font-weight: 500;
  font-variation-settings: "MONO" 0, "CASL" 1, "CRSV" 0, "slnt" 0;
}

h3 {
  font-size: 1.618rem;
  font-variation-settings: "MONO" 0, "CASL" 1, "CRSV" 0, "slnt" 0;
}

header h2 + aside {
  font-size: 1rem;
  margin-top: -0.5em !important;
}
header h2 + aside + aside.tags {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 1em 1ex;
}
header h2 + aside + aside.tags * {
  margin: 0;
  background-color: #d0a3e2;
  padding: 1ex 1em 1ex 1em;
  font-weight: 800;
  font-variation-settings: "MONO" 1, "CASL" 1, "CRSV" 0, "slnt" -15;
}

.flex.art a img, .flex.gallery a img {
  background: #a17eaf;
}

footer aside.tags {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 1em 1ex;
}
footer aside.tags * {
  margin: 0;
  background-color: #d0a3e2;
  padding: 1ex 1em 1ex 1em;
  font-weight: 800;
  font-variation-settings: "MONO" 1, "CASL" 1, "CRSV" 0, "slnt" -15;
}
footer #buildinfo {
  font-size: 0.6180469716rem;
  background-color: #fff;
  border: 1px ridge #ccc;
  border-collapse: collapse;
  margin: 0;
  padding: 1ch 2ch;
}
footer #buildinfo div {
  text-align: center;
}

* {
  box-sizing: border-box;
}

html,
body,
div,
header,
nav,
main,
footer {
  max-inline-size: none;
}

#koring table {
  border: ridge;
}

#koring-index ul, .critterlist ul {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: 0.5em;
  list-style-type: none;
}
#koring-index ul + ul, .critterlist ul + ul {
  margin-top: 1ch;
}
#koring-index ul li, .critterlist ul li {
  margin: 0;
  display: flex;
  height: 31px;
  align-items: center;
  width: 88px;
}
#koring-index ul li a, .critterlist ul li a {
  width: 88px;
  height: 31px;
}
#koring-index ul li a:not(:has(img)), .critterlist ul li a:not(:has(img)) {
  background: #d0a3e2;
  color: white;
  overflow: clip;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  font-size: 70%;
  border-color: #dedede #000 #000 #dedede;
  border: outset 2px;
}

pre {
  padding: 0 1em;
  overflow: auto;
  margin-bottom: 0.5em;
}
pre[data-linenos] {
  padding: 1em 0;
}
pre table td {
  padding: 0;
  border: unset;
  text-align: unset;
}
pre table tr {
  border: none;
}
pre mark {
  display: block;
  background-color: rgba(254, 252, 232, 0.9);
}
pre table {
  width: 100%;
  border-collapse: collapse;
  border: unset;
  background-color: unset;
  margin: unset;
  padding: unset;
  table-layout: unset;
}

pre, code {
  font-family: recursivevariable, sans-serif;
  font-variation-settings: "MONO" 1, "CASL" 1, "CRSV" 1, "slnt" -5;
}

body {
  margin: auto;
  min-block-size: 100vh;
  flex-direction: column;
}

footer {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  margin-bottom: 1em;
  justify-content: center;
}

.center\:vert {
  display: flex;
  align-items: center;
  justify-content: center;
}

.text-align\:center {
  text-align: center;
}

.filters {
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 2ex;
  justify-content: center;
}
.filters h3 {
  margin-bottom: 0.75em;
}
.filters * {
  display: inline-block;
}
.filters label {
  cursor: pointer;
  transition: all 0.1s;
}
.filters label:hover {
  text-decoration: underline;
  font-weight: 500;
}

header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 1em;
  width: 100%;
}
header img {
  max-block-size: 6em;
}
header * {
  margin: 0;
}

ol {
  padding: 0;
}

.content {
  flex-direction: column;
  block-size: clamp(768px, 75dvh, 100dvh - 25ch - 2em);
  aspect-ratio: 4/3;
  border: ridge;
  padding: 2ch;
  overflow: auto;
}
.content main {
  display: flex;
  flex-direction: column;
  margin-top: 0;
}
.content main > img {
  border: ridge;
  align-self: center;
  max-inline-size: 25%;
}

.blog-post {
  display: flex;
  flex-direction: column;
  line-height: 1.5;
}
.blog-post img {
  max-block-size: 20em;
}
.blog-post p:has(img:only-child), .blog-post p:has(img + img) {
  align-self: center;
  display: flex;
  align-items: center;
  width: 100%;
}
.blog-post p:has(img + img) {
  flex-direction: row;
  justify-content: center;
  gap: 1em;
}
.blog-post p:has(img:only-child) {
  flex-direction: column;
}
.blog-post pre {
  width: 100%;
  align-self: center;
}

input[type=radio][name=rating] {
  display: none;
}

input[type=radio][id=explicit]:checked ~ div.flex.gallery a:not([data-rating=Explicit]),
input[type=radio][id=questionable]:checked ~ div.flex.gallery a:not([data-rating=Questionable]),
input[type=radio][id=everyone]:checked ~ div.flex.gallery a:not([data-rating=Everyone]) {
  display: none;
}

.column.three {
  columns: 3;
}

.flex {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em;
  justify-content: center;
  align-items: center;
}
.flex * + * {
  margin-top: 0;
}
.flex:has(.kink) {
  align-items: flex-start;
}
.flex > .kink {
  width: 30ch;
}
.flex.gallery .year {
  flex-basis: 100%;
  text-align: center;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #d0a3e2 25%, #d0a3e2 75%, rgba(255, 255, 255, 0) 100%);
}
.flex.gallery a {
  width: 15em;
  min-height: 15em;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: #000;
  border: outset 4px;
  border-color: #dedede #000 #000 #dedede;
  overflow: hidden;
}
.flex.gallery a img {
  width: calc(15em - 8px);
  height: calc(15em - 8px);
  object-fit: cover;
}
.flex.gallery a[data-rating=Explicit] span {
  background-color: #fecece;
}
.flex.gallery a[data-rating=Questionable] span {
  background-color: #fefece;
}
.flex.gallery a[data-rating=Everyone] span {
  background-color: #cefece;
}
.flex.gallery a span {
  width: 100%;
  margin: 0;
  text-align: center;
  background-color: #cecece;
  z-index: 999;
}
.flex:first-child {
  margin-top: unset;
}
.flex:last-child {
  margin-bottom: unset;
}
.flex img {
  max-width: 33dvw;
}
.flex.ref {
  flex-direction: column;
}
.flex.ref section h3 {
  text-align: center;
}
.flex.ref details {
  width: 100%;
  text-align: center;
}
.flex.ref details a {
  max-inline-size: 50%;
  display: flex;
  gap: 0;
  margin: 0 auto 0.5em;
}
.flex.ref details a img {
  max-width: 100%;
}
.flex.art {
  flex-direction: column;
  align-items: center;
}
.flex.art video {
  width: 75%;
}
.flex.art a {
  text-align: center;
}
.flex.art a img {
  border: ridge 2px;
  border-color: #000 #dedede #dedede #000;
  max-inline-size: 50dvw;
  max-block-size: 50dvh;
}
.flex.art aside a {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column-reverse;
}
.flex.art aside a img {
  inline-size: 25ch;
  aspect-ratio: 1/1;
  object-fit: contain;
}
.flex.art p:first-child {
  margin-top: 1em;
}
.flex.art p + p {
  margin-top: 1em;
}

.flexbreak\:row {
  flex-basis: 100%;
  height: 0;
}

footer * {
  margin: unset;
}

p + p,
p:first-of-type {
  margin-top: 0.25em;
  margin-bottom: 0.25em;
}

@media screen and not (orientation: landscape) {
  .content {
    inline-size: unset;
    block-size: unset;
    aspect-ratio: unset;
    margin: 1em;
  }
  footer {
    margin-bottom: 5em;
  }
}
@media screen and (max-width: 1280px) {
  header img {
    max-width: 100%;
  }
  .content {
    inline-size: calc(100dvw - 4ch - 2em);
    block-size: calc(90dvh - 4ch - 2em);
  }
  .content .button {
    max-height: unset;
  }
}

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