Dancing Script + 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 — Dancing Script over Lora, in the wild.

Dancing Script 700 / Lora 400 — click any section and type your own copy.

Why it works

Both faces have calligraphic roots — Dancing Script overtly, Lora quietly in its brushed curves — so the pairing feels like two registers of the same hand rather than a script bolted onto an unrelated sans. Lora's serif texture also photographs better against invitation-style layouts than a plain sans would. The result is softer and more romantic than Dancing Script over Open Sans: the natural pick for weddings and personal writing where warmth should run all the way through the page.

More about each face: Dancing Script · 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=Dancing+Script:wght@700&family=Lora:wght@400;600&display=swap" rel="stylesheet">
CSS
h1, h2, h3 {
  font-family: 'Dancing Script', 'Brush Script MT', 'Segoe Script', cursive;
  font-weight: 700;
}

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

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

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

Related pairings