IBM Plex Mono + IBM Plex Sans
Grumpy wizards make toxic brew
A standfirst set in IBM Plex Sans, one size up — where a pairing starts earning trust.
The five boxing wizards jump quickly over the lazy dog, mixing jugs of quiet vodka while the jury watches. Click anywhere in this preview and type your own text to try the pairing.
“Type is a beautiful group of letters, not a group of beautiful letters.”
— Matthew Carter
Fig. 1 — IBM Plex Mono over IBM Plex Sans, in the wild.
IBM Plex Mono 600 / IBM Plex Sans 400 — click any section and type your own copy.
Why it works
Setting headlines in a monospace flips the usual hierarchy trick: IBM Plex Mono's typewriter cadence and Selectric-inspired details make headings feel engineered, while Plex Sans — drawn on the same skeletons with matching vertical metrics — reads effortlessly in paragraphs. Because both come from one superfamily the pairing cannot clash, which makes it a safe route to the developer-tool aesthetic without resorting to code-editor cliches.
More about each face: IBM Plex Mono · IBM Plex Sans
Use this pairing
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@600&family=IBM+Plex+Sans:wght@400;600&display=swap" rel="stylesheet">h1, h2, h3 {
font-family: 'IBM Plex Mono', 'Courier New', Courier, monospace;
font-weight: 600;
}
body {
font-family: 'IBM Plex Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
font-weight: 400;
}import { IBM_Plex_Mono, IBM_Plex_Sans } from "next/font/google";
const heading = IBM_Plex_Mono({
subsets: ["latin"],
weight: "600",
variable: "--font-heading",
});
const body = IBM_Plex_Sans({
subsets: ["latin"],
weight: "400",
variable: "--font-body",
});