/* Self-hosted typography: Fraunces (display) + Recursive (body)

   Expected font files (WOFF2 preferred):
   - /static/fonts/fraunces/Fraunces-VariableFont_SOFT,WONK,opsz,wght.woff2
   - /static/fonts/recursive/Recursive-VariableFont_CASL,CRSV,MONO,slnt,wght.woff2
*/

@font-face {
  font-family: "Fraunces";
  src: url("/static/fonts/fraunces/Fraunces-VariableFont_SOFT,WONK,opsz,wght.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Recursive";
  src: url("/static/fonts/recursive/Recursive-VariableFont_CASL,CRSV,MONO,slnt,wght.woff2") format("woff2");
  font-weight: 300 1000;
  font-style: oblique 0deg 15deg;
  font-display: swap;
}

:root {
  --font-display: "Fraunces", ui-serif, Georgia, serif;
  --font-body: "Recursive", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

html {
  font-family: var(--font-body);
  font-variation-settings: 'CASL' 0, 'CRSV' 0.5, 'MONO' 0;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Headings / brand elements */
h1, h2, h3,
.nav-brand__label,
.app-title,
.brand,
.logo {
  font-family: var(--font-display);
  letter-spacing: 0.01em;
}
