:root {
  --font-body: warbler-text, serif;
  --font-title: warbler-deck, var(--font-body);
  --font-display: warbler-display, var(--font-body);
  --font-sub: forma-djr-micro, sans-serif;
  
  --font-size: clamp(16px, 3.5vw, 20px);
  --font-size-md: 1.25em;
  --font-size-sm: .9em;
  --font-size-xs: .85em;

  --width-page-border: clamp(.3em, 2vw, 1em);
  --width-content: 650px;
}


[data-theme="kirby"] {
  --red: #C82817;

  --pink: #D94C67;
  --pink-dark: #B8233F;
  --pink-light: #DEAFBE;

  --blue: #4554cc;
  --blue-dark: #313d9c;
  --blue-faint: #4c6595;

  --orange: #FB7541;
  --yellow: #ffd17b;


  --accent: var(--red);
  --complement: var(--blue);
  --tertiary: var(--pink);

  --bg-main: #f5dee6;
  --bg-secondary: #edd4de;

  --bg-alt: #e2d1ec;
  --bg-alt-highlight: hsl(250, 17%, 82%);
  --bg-page: #e2bcc9;
  --bg-code: var(--bg-alt);


  /* Text */
  --text: #44110B;
  --text-secondary: var(--blue);
  --text-tertiary: var(--blue);
  --text-faint: #90405C;
  
  --text-alt: #1D0B44;

  --text-h1: var(--accent);
  --text-code: #3B3273;

  --link: var(--pink-dark);
  --link-hover: var(--blue);
  --link-decoration: var(--pink-light);
  --link-decoration-hover: var(--pink-light);

  --link-alt: var(--blue-dark);
  
  --highlight: var(--yellow);
  --highlight-text: var(--text);

  --border: #c293a3;
  --border-faint: #e4c2ce;
  --border-alt: #aca3cf;

  --ul-mark: var(--pink);
  --ul-mark-2: var(--blue);
  --ol-mark: var(--ul-mark);

  --site-title: var(--accent);
}

body {
  background: var(--bg-main);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--font-size);
  line-height: 1.25;
  margin: 0;
  padding: 20px;
  border: var(--width-page-border) solid var(--bg-page);
}

::selection {
  background: var(--highlight);
  color: var(--highlight-text);
}

a {
  color: var(--link);
  text-decoration-color: var(--link-decoration);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: .2s ease-in-out;
}
a:hover {
  color: var(--link-hover);
  text-decoration-color: var(--link-decoration-hover);
}


.site-nav {
  width: 100%;
  max-width: var(--width-content);
  margin-inline: auto;
  margin-block: 3em
}
.site-nav ul {
  list-style-type: none;
  margin: 0;
  padding: 0;

  display: flex;
  flex-wrap: wrap;
  column-gap: 1em;

  font-family: var(--font-sub);
  font-size: var(--font-size-sm);
}


main {
  width: 100%;
  max-width: var(--width-content);
  margin-inline: auto;
}

.page-header {
  margin-bottom: 3em;
}
h1 {
  font-family: var(--font-display);
  font-weight: normal;
  margin-block: 0;
}
.page__desc {
  line-height: 1.5;
}



.link {
  padding-block: 1em;
}
.link + .link {
  border-top: 1px solid var(--border-faint);
}

.link__title {
  line-height: 1.35;
  margin-block: 0 .5em;

  /* display: flex;
  flex-wrap: wrap;
  gap: .5em;
  align-items: baseline; */
}
.link__title > a {
  font-size: var(--font-size-md);
  display: inline;
  margin-right: .15em;
}

.link__author {
  margin-top: .5em;
}

.link__domain {
  background: var(--bg-alt);
  color: var(--text-code);
  font-family: var(--font-sub);
  font-size: var(--font-size-xs);

  border-radius: 4px;
  line-height: 1;
  padding: .1em .4em .18em;
}

.link__comment {
  line-height: 1.5;
}

.link__publication {
  font-style: italic;
  margin-block: 0 .5em;
  /* font-family: var(--font-display);
  font-variant: all-small-caps;
  font-size: var(--font-size-md);
  letter-spacing: .1em; */
}


.quotes {
  list-style: none;
  margin: 1em 0 1.25em;
  padding: 0;

  font-size: var(--font-size-sm);
}
.quotes li {
  margin: 0;
}
blockquote {
  border-left: 1px solid var(--border);
  margin-left: 2em;
  padding-left: 1em;
}



.link__metadata { 
  font-family: var(--font-sub);
  font-size: var(--font-size-sm);
  
  display: flex;
  flex-wrap: wrap;
  column-gap: .5em;

}
.link__via > a {
  color: var(--text);
}
.link__via > a:hover {
  color: var(--link-hover);
}

.tags {
  list-style: none;
  margin: 0;
  padding: 0;  

  display: flex;
  flex-wrap: wrap;
  column-gap: .5em;

  color: var(--text-faint);

}
.tag::before {
  content: '#';
  opacity: .7;
}


.site-footer {
  width: 100%;
  max-width: var(--width-content);
  margin-inline: auto;
  margin-block: 5em;

  font-size: var(--font-size-xs);
}