Cabin + Lora

Grumpy wizards make toxic brew

A standfirst set in Lora, 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 — Cabin over Lora, in the wild.

Cabin 600 / Lora 400 — click any section and type your own copy.

Why it works

Cabin's Johnston-inspired humanist forms carry a gentle, hand-touched warmth that most geometric sans headings lack, and Lora's calligraphic roots give body text the same quality at reading sizes. Because both faces are rounded and moderately proportioned, the pairing feels homogeneous in mood while still keeping the sans-versus-serif contrast that makes hierarchy obvious. Well suited to personal blogs and small studios that want approachable rather than slick.

More about each face: Cabin · Lora

Use this pairing

HTML — Google Fonts embed
<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=Cabin:wght@600&family=Lora:wght@400;600&display=swap" rel="stylesheet">
CSS
h1, h2, h3 {
  font-family: 'Cabin', Verdana, 'Segoe UI', Arial, sans-serif;
  font-weight: 600;
}

body {
  font-family: 'Lora', Georgia, 'Times New Roman', serif;
  font-weight: 400;
}
Next.js — next/font
import { Cabin, Lora } from "next/font/google";

const heading = Cabin({
  subsets: ["latin"],
  weight: "600",
  variable: "--font-heading",
});

const body = Lora({
  subsets: ["latin"],
  weight: "400",
  variable: "--font-body",
});

Related pairings