For the agent-readable index of this site, see /llms.txt.
Aesop
Aesop's identity since the 1987 founding has been built from typography and packaging rather than chromatic logo work. The chassis stays warm and restrained — unbleached-paper cream, deep umber type, generous margins, narrow serif rhythm — so the wordmark and product hierarchy carry the brand voice. The Australian apothecary discipline asserts identity through what it omits: no display weight, no chromatic accent, no decoration.
Cream Edition
The apothecary-counter register: warm cream canvas evoking the unbleached paper of Aesop's product labels, deep umber as the type signal, the restraint of a brand whose chrome is built from typography and packaging rather than chromatic identity. The atmosphere reads that Australian-minimalism discipline — generous margins, narrow serif rhythm, accents reserved for the wordmark and product hierarchy. A study in how a beauty brand can stage 35 years of identity through restraint and a single muted ink.
Install at runtime
Run this snippet in any browser console where Void Energy is loaded (or paste it into your app's bootstrap). The atmosphere registers with the engine and renders immediately as a temporary preview — it persists in the visitor's preferences only if they Apply it site-wide.
Physics: flat
Mode: light
Density: x1.18
Live preview
A believable product moment rendered against the active atmosphere. Hover, focus, and toggle the controls — typography weight, button tracking, corner radii, and motion timing all carry the brand's identity.
Workspace settings
Welcome back
Configure how you collaborate, then jump back into the channels you were active in.
Search by name or email — Combobox with descriptions.
Recent channels
Typography
Headings, body, and signal text rendered against the active atmosphere.
Typefaces
The active heading and body families — brand override first, atmosphere default second.
Heading · --font-heading
Cormorant Garamond
Body · --font-body
Cormorant Garamond
Heading scale
Six levels, each picking up the brand's weight, tracking, and transform tokens.
h1 — Aesop
h2 — Cream Edition
h3 — Subsection
h4 — Section header
h5 — Subheading
h6 — Minor subheading
Body & secondary text
Standard reading copy and supporting metadata.
Paragraph — body typography, dim color. Standard readable text for descriptions and content.
Small — small typography, mute color. Used for captions and metadata.Caption — caption level utility class.
Brand overrides
Beyond the typeface, brand profiles can tune weight, tracking, and text-transform per
role. Display covers h1/h2, Heading covers h3/h4, Body covers paragraphs and small
text, Button covers all .btn-* labels. Anything not declared
inherits from the atmosphere's defaults.
Supported overrides & this brand's values
A brand profile can override 4 weights, 4 trackings, and 3 transforms (Body has no transform — prose never gets uppercased).
- Display weight (h1, h2) ·
--weight-display400 - Display tracking (h1, h2) ·
--tracking-display0.04em - Display transform (h1, h2) ·
--text-transform-display… - Heading weight (h3, h4) ·
--weight-heading400 - Heading tracking (h3, h4) ·
--tracking-heading0.04em - Heading transform (h3, h4) ·
--text-transform-heading… - Body weight (p, small) ·
--weight-body… - Body tracking (p, small) ·
--tracking-body0.02em - Button weight (.btn-*) ·
--weight-button400 - Button tracking (.btn-*) ·
--tracking-button… - Button transform (.btn-*) ·
--text-transform-button…
Palette & shape
The color palette, corner geometry, and motion curves under the active atmosphere. Atmospheres change the values; the architecture never moves.
Energy — Brand axis
The two colors that change most per atmosphere. Primary drives CTAs, focus rings, and headings. Secondary tints hovers, press feedback, toggle thumbs, and the selected channel in the live preview above.
energy-primaryenergy-secondarySurfaces
Background layers from the depth model. Canvas is
the floor — sunk and spotlight are its recess and ambient variants. Surface is where floating elements live. Every tile carries --border-color at var(--physics-border-width), so the border tier is
visible on each outline.
bg-canvasbg-sunkbg-spotlightbg-surfaceSignal — Text hierarchy
Three emphasis levels for information hierarchy.
Color extensions
Two additional palettes layered on top of the five-layer system. Neither is a brand-axis variable, so they don't change much per atmosphere.
Semantic — success, error, premium, and system carry the same meaning on every brand. Most brands inherit the defaults; the rare override applies when a brand's primary hue would clash (e.g. a green primary forces a different success green).
Positive outcome
Destructive, failure
Attention, cost
Informational
Data palette — 8 categorical slots derived from primary
Hue-rotated 45° per step from --energy-primary in
OKLCH. Cool atmospheres yield cool-leaning palettes; warm yield
warm-leaning. Use for chart series, chips, tags, kanban columns,
avatar fallbacks, and calendar categories — anywhere
unrelated-by-severity data needs distinct identity. Not for severity (data-3 means
"third slot," not "success"). Auto-contrast handles text color on
any bg-data-* tile.
data-1data-2data-3data-4data-5data-6data-7data-8Radii — corner geometry
All five radius levels, rendered with the active atmosphere's tokens. Brand-overridden values are emphasized.
--radius-sm 0--radius-md 0--radius-lg 2px--radius-xl 2px--radius-full …Motion
Brand profiles can also override the system's speeds and easing
curves. The square below uses --speed-slow and --ease-spring-snappy — both carried by the brand axis
when set, otherwise inherited from the active physics preset. Hover the demo to play.
Supported overrides & this brand's values
A brand profile can override 3 speed levels and 4 easing curves. Anything not declared inherits
from the active physics preset (glass / flat / retro). Cascade
delays (--delay-cascade, --delay-sequence) are physics-only and not part of
the brand axis.
- Fast ·
--speed-fast… - Base ·
--speed-base360ms - Slow ·
--speed-slow560ms - Flow ·
--ease-flowcubic-bezier(0.4, 0, 0.2, 1) - Spring (gentle) ·
--ease-spring-gentle… - Spring (snappy) ·
--ease-spring-snappy… - Spring (bounce) ·
--ease-spring-bounce…