: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, 4vw, 22px);
  --font-size-md: 1.25em;
  --font-size-sm: .9em;
  --font-size-xs: .85em;

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


[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.5;
  margin: 0;
  padding: 20px;
  border: var(--width-page-border) solid var(--bg-page);
}

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

img {
  max-width: 100%;
}

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-measure);
  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-container);
  margin-inline: auto;
}

.page-header {
  text-align: center;
  margin-block: 3em;
}
h1 {
  font-family: var(--font-display);
  font-weight: normal;
  margin-block: 0;
}
.page__desc {
  font-size: var(--font-size-sm);
  font-style: italic;
  line-height: 1.5;
}


section p {
  margin-inline: auto;
  max-width: var(--width-measure);
  width: 100%;
}

figure {
  margin-inline: 0;
  margin-top: 3em;
}

figure + figure {
  margin-top: 4em;
}

figcaption {
  color: var(--text-faint);
  font-family: var(--font-sub);
  font-size: var(--font-size-sm);
  max-width: var(--width-measure);
  margin-inline: auto;
  margin-top: .5em;
  text-align: center;
  width: 100%;
}


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

  font-variant-caps: all-small-caps;
  /* font-size: var(--font-size); */
  text-align: center;
}