/* --- BEGIN VARIABLES --- */
:root {
  /* FONT */
  font-size: calc(12px + 0.3vw);
  --qx-unit-text: calc(1px + 0.013vw);

  --qx-sans: Lexend, sans-serif;
  --qx-serif: Vollkorn, serif;
  --qx-mono: Inconsolata, monospace;

  /* COLORS */
  --qx-main-darker: hsl(190, 40%, 25%);
  --qx-main-dark: hsl(175, 70%, 30%);
  --qx-main-light: hsl(180, 60%, 40%);
  --qx-main-lighter: hsl(160, 40%, 75%);
  --qx-accent-darker: hsl(345, 85%, 30%);
  --qx-accent-dark: hsl(5, 50%, 45%);
  --qx-accent-light: hsl(5, 55%, 60%);
  --qx-accent-lighter: hsl(20, 50%, 65%);
  --qx-selection-dark: hsl(190, 20%, 35%);
  --qx-selection-light: hsl(190, 20%, 65%);
  --qx-light: hsl(155, 20%, 97%);
  --qx-medlight: hsl(30, 20%, 93%);
  --qx-meddark: hsl(340, 15%, 15%);
  --qx-dark: hsl(220, 10%, 8%);

  --qx-rainbow-color: #e26e4b;
}

/* THEMES */
  /* LIGHT THEME */
@media (prefers-color-scheme: light) { :root {
  --qx-foreground: var(--qx-dark);
  --qx-nearground: var(--qx-meddark);
  --qx-midground: var(--qx-medlight);
  --qx-background: var(--qx-light);
  --qx-main-fore: var(--qx-main-darker);
  --qx-main-mid: var(--qx-main-dark);
  --qx-main-back: var(--qx-main-lighter);
  --qx-accent-fore: var(--qx-accent-darker);
  --qx-accent-mid: var(--qx-accent-dark);
  --qx-accent-back: var(--qx-accent-light);
  --qx-selection: var(--qx-selection-light);
} }
  /* DARK THEME */
@media (prefers-color-scheme: dark) { :root {
  --qx-foreground: var(--qx-light);
  --qx-midground: var(--qx-meddark);
  --qx-background: var(--qx-dark);
  --qx-main-fore: var(--qx-main-lighter);
  --qx-main-mid: var(--qx-main-light);
  --qx-main-back: var(--qx-main-darker);
  --qx-accent-fore: var(--qx-accent-lighter);
  --qx-accent-mid: var(--qx-accent-light);
  --qx-accent-back: var(--qx-accent-dark);
  --qx-selection: var(--qx-selection-dark);
} }

:root {
  /* APPLY THEME */
  --qx-nearground: color-mix(in oklab, var(--qx-foreground), var(--qx-midground) 80%);
  --qx-main-far: color-mix(in oklab, var(--qx-main-mid), var(--qx-main-back));
  --qx-main-near: color-mix(in oklab, var(--qx-main-mid), var(--qx-main-fore));
  --qx-accent-far: color-mix(in oklab, var(--qx-accent-mid), var(--qx-accent-back));
  --qx-accent-near: color-mix(in oklab, var(--qx-accent-mid), var(--qx-accent-fore) 40%);
}

/* COLOR ANIMATED */
@keyframes rainbow {
  0%, 1%, 99%, 100% {
    color: var(--qx-accent-mid);
  }
  11.5%, 13.5% {
    color: #f5a6bb;
  }
  24%, 26% {
    color: #8abd48;
  }
  36.5%, 38.5% {
    color: #f5e35b;
  }
  49%, 51% {
    color: #8848b0;
  }
  61.5%, 63.5% {
    color: #6373e0;
  }
  74%, 76% {
    color: #123838;
  }
  86.5%, 88.5% {
    color: #99e9f0;
  }
}
/* --- END VARIABLES --- */

/* --- BEGIN MISCELLANEOUS --- */
* {
  margin: 0;
  padding: 0;
}

html {
  font-family: var(--qx-serif);
  font-weight: 400;
  color: var(--qx-foreground);
}

body {
  min-width: 180px;
  max-width: 720px;
  width: auto;
  margin: auto;
  background: var(--qx-background);
  padding: 1rem;
}

::selection {
  --qx-selection-color: var(--qx-foreground);
  --qx-selection-background: var(--qx-selection);
  color: var(--qx-selection-color);
  background-color: var(--qx-selection-background);
  text-decoration-color: var(--qx-selection-color);
}

.l-flex {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
}

.l-flex--column {
  flex-direction: column;
}

.l-flex--row {
  flex-direction: row;
}
/* --- END MISCELLANEOUS --- */

/* --- BEGIN NAVBAR --- */
.m-navbar {
  --qx-menu-link-color: var(--qx-main-mid);
  --qx-menu-link-hover: var(--qx-main-fore);
  --qx-menu-background-active: var(--qx-midground);
  --qx-menu-background-hover: var(--qx-midground);
  --qx-scalar: 14;
  font-family: var(--qx-serif);
  font-weight: 700;
  font-size: calc(var(--qx-scalar) * var(--qx-unit-text));
  padding: 0;
  color: var(--qx-menu-link-color);
}

.m-navbar * {
  color: var(--qx-menu-link-color);
}

.m-navbar__list {
  list-style-type: none;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin: 0;
  padding: 0;
}

.m-navbar__label {
  border-radius: 0.6rem;
  padding: 0.3rem 0.5rem;
}

.is-active .m-navbar__label {
  background: var(--qx-menu-background-active);
}

.m-navbar__label:hover {
  background-color: var(--qx-menu-background-hover);
  --qx-menu-link-color: var(--qx-menu-link-hover);
}
/* --- END NAVBAR --- */

/* --- BEGIN SITE HEADER --- */
/* not to be confused with the site banner */
.m-site-header {
  --qx-border-width: 0.15rem;
  --qx-border-color: var(--qx-main-near);
  padding-bottom: 1rem;
  border-bottom: var(--qx-border-width) solid var(--qx-border-color);
  gap: 1rem;
}
/* --- END SITE HEADER --- */

/* --- BEGIN SITE BANNER --- */
.m-site-banner {
  --qx-site-title-color: var(--qx-accent-mid);
  --qx-site-tagline-color: var(--qx-main-far);
  --qx-status-link-color: var(--qx-accent-far);
  --qx-status-hover-color: var(--qx-accent-near);
  gap: 1rem;
  align-items: start;
}

.m-site-banner__container {
  gap: 0.3rem;
}

.m-site-banner__logo {
  height: 4rem;
  width: 4rem;
}

.m-site-banner__site-title {
  font-family: var(--qx-sans);
  font-size: 1.5rem;
  font-weight: 500;
  margin: 0;
  color: var(--qx-site-title-color);
  animation: 25s 1s infinite rainbow;
}

.m-site-banner__site-title * {
  color: inherit;
}

.m-site-banner__tagline {
  font-family: var(--qx-mono);
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--qx-site-tagline-color);
  margin: 0;
  line-height: 1.5em;
}

.m-site-banner__status-link {
  font-weight: 800;
  font-size: 0.95em;
  color: var(--qx-status-link-color);
}

.m-site-banner__status-link:hover {
  --qx-status-link-color: var(--qx-status-hover-color);
}
/* --- END SITE BANNER --- */

/* --- BEGIN SITE FOOTER --- */
.m-site-footer {
  --qx-border-width: 0.15rem;
  --qx-border-color: var(--qx-main-near);
  --qx-footer-color: var(--qx-main-near);
  --qx-footer-link-color: var(--qx-accent-near);
  --qx-footer-link-hover-color: var(--qx-accent-fore);
  margin-top: 1rem;
  border-top: var(--qx-border-width) solid var(--qx-border-color);
  padding-top: 1rem;
  gap: 0.5rem;
  color: var(--qx-footer-color);
  line-height: 1.2em;
}

.m-site-footer a {
  color: var(--qx-footer-link-color);
}

.m-site-footer a:hover {
  color: var(--qx-footer-link-hover-color);
}
/* --- END SITE FOOTER --- */

/* --- BEGIN BUTTON --- */
/* not to be confused with m-buttons.
  m-button is for interactive button placement
  m-buttons is for 88x31 images */
.m-button {
  --foreground-color: var(--qx-main-fore);
  --background-color: var(--qx-midground);
  --border-color: var(--qx-nearground);
  list-style: none;
  border: 1px solid var(--border-color);
  border-radius: 0.6rem;
  padding: 0.4rem;
  color: var(--foreground-color);
  background: var(--background-color);
  text-decoration: underline;
}

.m-button:hover {
  --foreground-color: var(--qx-main-fore);
  --background-color: color-mix(in oklab, var(--qx-accent-fore), var(--qx-background) 70%);
  --border-color: var(--qx-main-back);
  color: var(--foreground-color);
  background: var(--background-color);
  border-color: var(--border-color);
}
/* --- END BUTTON --- */

/* --- BEGIN 88x31 BUTTONS --- */
.m-buttons {
  gap: 0.2rem;
}

.m-buttons__container {
  flex-wrap: wrap;
  gap: 0.4rem;
}
/* --- END BUTTONS --- */

/* --- BEGIN ARTICLE --- */
.m-article {
  --title-color: var(--qx-main-near);
  --subtitle-color: var(--qx-main-fore);
  --subtitle-link-color: var(--qx-main-mid);
  --subtitle-hover-color: var(--qx-main-fore);
  --description-color: var(--qx-accent-near);
  --description-size: 15;
  --description-link-color: var(--qx-accent-back);
  --description-link-hover-color: var(--qx-accent-near);
  --date-size: 13;
  --date-color: var(--qx-main-near);
  --content-size: 17;
  --content-color: var(--qx-foreground);
  --link-color: var(--qx-accent-mid);
  --link-hover-color: var(--qx-accent-fore);
  --h2-color: var(--qx-main-mid);
  --h3-color: var(--qx-accent-far);
  --h4-color: var(--qx-main-near);
  --h5-color: var(--qx-main-fore);
  --h6-color: var(--qx-foreground);
  --footer-size: 16;
  --footer-color: var(--qx-main-fore);
  --footer-link-color: var(--qx-accent-near);
  --footer-hover-color: var(--qx-accent-fore);
  --tags-size: 17;
}

.m-article__title {
  font-family: var(--qx-sans);
  font-weight: 700;
  font-size: 2.2rem;
  color: var(--title-color);
  margin: 1.4rem 0 0.5rem 0;
}

.m-article__subtitle {
  font-family: var(--qx-sans);
  font-weight: 800;
  font-size: 1.5rem;
  color: var(--subtitle-color);
  margin: 0 0 0.5rem 0;
}

.m-article__subtitle a {
  color: var(--subtitle-link-color);
}

.m-article__subtitle a:hover {
  color: var(--subtitle-hover-color);
}

.m-article__description {
  font-weight: 500;
  font-size: calc(var(--description-size) * var(--qx-unit-text));
  color: var(--description-color);
  margin: calc(var(--description-size) * var(--qx-unit-text) * 0.6) 0 0 0;
}

.m-article__description a {
  color: var(--description-link-color);
}

.m-article__description a:hover {
  color: var(--description-link-hover-color);
}

.m-article__date {
  font-family: var(--qx-serif);
  font-weight: 700;
  font-size: calc(var(--date-size) * var(--qx-unit-text));
  color: var(--date-color);
  margin: 0.6rem 0 0 0;
}

.m-article__permalink {
  margin: 0.4rem 0;
  font-family: var(--qx-mono);
  font-weight: 700;
}

.m-article__content {
  line-height: calc(1.35em + 0.75vw);
  font-size: calc(var(--content-size) * var(--qx-unit-text));
  color: var(--content-color);
}

.m-article__content p {
  margin: calc(0.6em + 0.5vw) 0;
}

.m-article__content > p:not(:first-of-type) {
  text-indent: 3rem;
}

.m-article__content > p a {
  color: var(--link-color);
}

.m-article__content> p a:hover {
  color: var(--link-hover-color);
  text-decoration: none;
}

.m-article__content h2 {
  font-weight: 800;
  font-size: 1.6em;
  margin: 1.6rem 0 0.6rem 0;
  color: var(--h2-color);
}

.m-article__content h3 {
  font-weight: 700;
  font-size: 1.45em;
  margin: 1.3rem 0 0.5rem 0;
  color: var(--h3-color);
}

.m-article__content h4 {
  font-weight: 600;
  font-size: 1.3em;
  margin: 1.2rem 0 0.4rem 0;
  color: var(--h4-color);
}

.m-article__content h5 {
  font-weight: 700;
  font-size: 1.15em;
  margin: 1.2rem 0 0.4rem 0;
  color: var(--h5-color);
}

.m-article__content h6 {
  font-weight: 600;
  font-size: 1.15em;
  margin: 1.2rem 0 0.4rem 0;
  color: var(--h6-color);
}

.m-article__home {
  font-size: calc(var(--content-size) * var(--qx-unit-text));
  color: var(--content-color);
}

.m-article__home h2 {
  font-weight: 800;
  font-size: 1.6em;
  margin: 1.6rem 0 0.6rem 0;
  color: var(--h2-color);
}

.m-article__home > p {
  margin: calc(0.6em + 0.5vw) 0;
}

.m-article__home > p a {
  color: var(--link-color);
}

.m-article__home > p a:hover {
  color: var(--link-hover-color);
  text-decoration: none;
}

.m-article__content blockquote {
  --font-size: calc(0.92 * 17); /* main text is 17 */
  --bar-width: 0.25rem;
  --bar-color: var(--qx-accent-near);
  --background: var(--qx-midground);
  background: var(--background);
  border-left: var(--bar-width) solid var(--bar-color);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.6rem 0.4rem;
  margin: 0.6rem 0;
  border-radius: var(--bar-width);
  font-size: calc(var(--font-size) * var(--qx-unit-text));
  padding-left: 3rem;
  padding-right: 1rem;
}

.m-article__content blockquote::before {
  content: "“";
  left: -2rem;
  top: 2rem;
}

.m-article__content blockquote::after {
  content: "”";
  text-align: end;
  right: -0.4rem;
  bottom: -0.5rem;
  margin-top: 0.15rem;
}

.m-article__content blockquote::before,
.m-article__content blockquote::after {
  font-size: 4rem;
  position: relative;
  line-height: 1rem;
}

.m-article__footer {
  margin: 0.8rem 0;
  font-weight: 600;
  line-height: 1.5em;
  font-size: calc(var(--footer-size) * var(--qx-unit-text));
  color: var(--footer-color);
}

.m-article__footer a {
  color: var(--footer-link-color);
}

.m-article__footer a:hover {
  color: var(--footer-hover-color);
}
/* --- END ARTICLE --- */

/* --- BEGIN LIST --- */
.m-list {
  --container-title-size: 24;
  --container-title-color: var(--qx-main-fore);
  --container-subtitle-size: 20;
  --container-subtitle-color: var(--qx-main-mid);
  --item-radius: 1rem;
  --item-color: none;
  --item-hover-color: var(--qx-midground);
  --item-title-size: 22;
  --item-title-color: var(--qx-accent-mid);
  --item-title-hover-color: var(--qx-accent-fore);
  --item-title-decoration: underline;
  --item-description-size: 15;
  --item-date-size: 15;
  --item-date-color: var(--qx-accent-fore);
  --item-date-hover-color: color-mix(in oklab, var(--qx-accent-fore), var(--qx-foreground) 50%);
  display: flex;
  flex-flow: column;
  gap: 1rem;
}

.m-list__container {
  display: flex;
  flex-flow: column;
}

.m-list__container-title {
  font-family: var(--qx-serif);
  font-size: calc(var(--container-title-size) * var(--qx-unit-text));
  font-weight: 600;
  color: var(--container-title-color);
  margin: 0.2rem 0;
}

.m-list__container-subtitle {
  font-size: calc(var(--container-subtitle-size) * var(--qx-unit-text));
  color: var(--container-subtitle-color);
}

.m-list__container-contents {
  display: flex;
  flex-flow: column;
  flex: 8;
  gap: 0.4rem;
  padding-left: 2rem;
}

.m-list__item {
  position: relative;
  border-radius: var(--item-radius);
  padding: 1rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}

.m-list__item:hover {
  background-color: var(--item-hover-color);
  --item-title-color: var(--item-title-hover-color);
  --item-title-decoration: none;
  --item-date-color: var(--item-date-hover-color);
}

.m-list__item-title {
  color: var(--item-title-color);
  text-decoration: var(--item-title-decoration);
  font-size: calc(var(--item-title-size) * var(--qx-unit-text));
  font-family: var(--qx-sans);
  font-weight: 700;
  margin-bottom: 0.4rem;
}

.m-list__item-link {
  text-decoration: none;
  color: inherit !important;
}

.m-list__item-link::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}

.m-list__item-description {
  font-size: calc(var(--item-description-size) * var(--qx-unit-text));
}

.m-list__item-date {
  font-size: calc(var(--item-date-size) * var(--qx-unit-text));
  color: var(--item-date-color);
}
/* --- END LIST --- */

/* --- BEGIN TAGS --- */
.m-tags {
  font-size: calc(var(--tags-size) * var(--qx-unit-text));
}

.m-tags__tag {
  font-family: var(--qx-mono);
  font-weight: 700;
}

.m-tags__tag::before {
  content: "#";
}

.m-tags__label {
  display: inline;
}
/* --- END TAGS ---*/

/* --- BEGIN NOTE --- */
.m-note {
  --font-size: calc(0.92 * 17); /* used to be 0.92em. does this hack suck y/n */
  --size: 0.25rem;
  --bar-color: var(--qx-accent-mid);
  --background: var(--qx-midground);
  --title-link-color: var(--qx-accent-mid);
  --title-hover-color: var(--qx-accent-fore);
  background-color: var(--background);
  border-left: var(--size) solid var(--bar-color);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.6rem 0.4rem;
  margin: 0.6rem 0;
  border-radius: var(--size);
  font-size: calc(var(--font-size) * var(--qx-unit-text));
}

.m-note > p { /* i hate doing this why do i do this */
  margin: 0;
}

.m-note__title { /* this > > */
  /* actually the defaults are all fine i think */
}

.m-note > p > a,
.m-note__title > a { /* > is inescapable */
  color: var(--title-link-color);
}

.m-note > p > a:hover,
.m-note__title > a:hover {
  color: var(--title-hover-color);
  text-decoration: none;
}
/* --- END NOTE --- */

/* --- BEGIN QUIPS --- */
.m-quip {
  --background: var(--qx-midground);
  --font-size: 13;
  --time-size: 12;
  --time-color: var(--qx-accent-near);
  --time-hover-color: var(--qx-accent-fore);
  --content-size: 14;
  display: flex;
  flex-flow: row;
  gap: 0.2rem;
  background-color: var(--background);
  border-radius: 0.2rem;
  padding: 0.4rem;
  font-size: calc(var(--font-size) * var(--qx-unit-text));
  margin: 0.4rem 0;
}

.m-quip__time {
  font-weight: 900;
  font-size: calc(var(--time-size) * var(--qx-unit-text));
  font-family: var(--qx-mono);
  flex: 0 0 7em;
}

.m-quip__time > a {
  color: var(--time-color);
}

.m-quip__time > a:hover {
  color: var(--time-hover-color);
}

.m-quip__content {
  font-weight: 500;
  font-size: calc(var(--content-size) * var(--qx-unit-text));
  font-family: var(--qx-mono);
  flex: 1 content;
}
/* --- END QUIPS --- */

/* --- BEGIN FANCY LINKS --- */
.h-fancy-links a:not([href^="#"]):not([href^="/"]):not([href^="./"]):not([href^="../"]):not([href^="mailto:"])::before,
.h-fancy-links a[href^="//"] {
  content: "🌐";
}

.h-fancy-links a[href^="/"]:not([href^="//"])::before,
.h-fancy-links a[href^="./"]::before,
.h-fancy-links a[href^="../"]::before {
  content: "🔆";
}

.h-fancy-links a[href^="#"]::before {
  content: "#️⃣";
}

.h-fancy-links a[href^="mailto:"]::before {
  content: "📧";
}

/* overrides fancy links for markdown headings.
 * we already generate an anchor link for each;
 * see querulous/layouts/_markup/render-heading.html */
.h-fancy-links a.h-heading__anchor::before {
  content: "";
}
/* --- END FANCY LINKS --- */

/* --- BEGIN ID ANCHOR (HEADING LINKS, ETC.) --- */
.h-heading {
  --heading-anchor-color: color-mix(in oklab, var(--qx-accent-back), var(--qx-background) 50%);
  --heading-anchor-hover-color: var(--qx-accent-far);
}

.h-heading__anchor {
  color: var(--heading-anchor-color);
}

.h-heading:hover {
  --heading-anchor-color: var(--heading-anchor-hover-color);
}
/* --- END ID ANCHOR --- */
