getdesign.mdgetdesign/revolut
Revolut
Fintech confidence with billboard-scale Aeonik display, near-black + white binary, universal pill buttons, and zero shadows.
install
npx designkit add getdesign/revolutpreviewrenderPreviewHtml
source
---
name: Revolut
description:
Fintech confidence with billboard-scale Aeonik display, near-black + white
binary, universal pill buttons, and zero shadows.
originalFonts:
primary: "Aeonik Pro"
fallbacks:
- "Arial"
colors:
background: "#ffffff"
surface: "#f4f4f4"
ink: "#191c1f"
ink-muted: "#505a63"
accent: "#191c1f"
accent-alt: "#494fdf"
border: "#c9c9cd"
link: "#376cd5"
revolut-dark: "#191c1f"
pure-white: "#ffffff"
light-surface: "#f4f4f4"
revolut-blue: "#494fdf"
action-blue: "#4f55f1"
blue-text: "#376cd5"
danger-red: "#e23b4a"
deep-pink: "#e61e49"
warning-orange: "#ec7e00"
yellow: "#b09000"
teal: "#00a87e"
light-green: "#428619"
green-text: "#006400"
light-blue: "#007bc2"
brown: "#936d62"
red-text: "#8b0000"
mid-slate: "#505a63"
cool-gray: "#8d969e"
gray-tone: "#c9c9cd"
typography:
h1:
family: "Inter"
size: "8.5rem"
weight: 500
lineHeight: 1.0
h2:
family: "Inter"
size: "5rem"
weight: 500
lineHeight: 1.0
h3:
family: "Inter"
size: "3rem"
weight: 500
lineHeight: 1.21
body:
family: "Inter"
size: "1rem"
weight: 400
lineHeight: 1.5
code:
family: "JetBrains Mono"
spacing:
xs: "0.5rem"
sm: "0.875rem"
md: "1rem"
lg: "1.5rem"
xl: "2.5rem"
rounded:
sm: "12px"
md: "12px"
lg: "20px"
xl: "9999px"
shadows:
sm: "none"
md: "none"
components:
button-primary:
background: "{colors.revolut-dark}"
color: "{colors.pure-white}"
border: "2px solid {colors.revolut-dark}"
radius: "{rounded.xl}"
padding: "14px 32px"
button-secondary:
background: "{colors.light-surface}"
color: "#000000"
border: "2px solid {colors.light-surface}"
radius: "{rounded.xl}"
padding: "14px 34px"
button-outlined:
background: "transparent"
color: "{colors.revolut-dark}"
border: "2px solid {colors.revolut-dark}"
radius: "{rounded.xl}"
padding: "14px 32px"
card:
background: "{colors.background}"
border: "none"
radius: "{rounded.lg}"
padding: "1.5rem"
input:
background: "{colors.light-surface}"
color: "{colors.ink}"
border: "1px solid {colors.border}"
radius: "{rounded.sm}"
padding: "0.625rem 1rem"
---
<!-- source: VoltAgent/awesome-design-md @ 80bbbc2 (MIT) — see ATTRIBUTION.md -->
# Design System Inspiration of Revolut
## 1. Visual Theme & Atmosphere
Revolut's website is fintech confidence distilled into pixels — a design system
that communicates "your money is in capable hands" through massive typography,
generous whitespace, and a disciplined neutral palette. The visual language is
built on Aeonik Pro, a geometric grotesque that creates billboard-scale
headlines at 136px with weight 500 and aggressive negative tracking (-2.72px).
This isn't subtle branding; it's fintech at stadium scale.
The color system is built on a comprehensive `--rui-*` (Revolut UI) token
architecture with semantic naming for every state: danger (`#e23b4a`), warning
(`#ec7e00`), teal (`#00a87e`), blue (`#494fdf`), deep-pink (`#e61e49`), and
more. But the marketing surface itself is remarkably restrained — near-black
(`#191c1f`) and pure white (`#ffffff`) dominate, with the colorful semantic
tokens reserved for the product interface, not the marketing page.
What distinguishes Revolut is its pill-everything button system. Every button
uses 9999px radius — primary dark (`#191c1f`), secondary light (`#f4f4f4`),
outlined (`transparent + 2px solid`), and ghost on dark
(`rgba(244,244,244,0.1) + 2px solid`). The padding is generous (14px 32px–34px),
creating large, confident touch targets. Combined with Inter for body text at
various weights and positive letter-spacing (0.16px–0.24px), the result is a
design that feels both premium and accessible — banking for the modern era.
**Key Characteristics:**
- Aeonik Pro display at 136px weight 500 — billboard-scale fintech headlines
- Near-black (`#191c1f`) + white binary with comprehensive `--rui-*` semantic
tokens
- Universal pill buttons (9999px radius) with generous padding (14px 32px)
- Inter for body text with positive letter-spacing (0.16px–0.24px)
- Rich semantic color system: blue, teal, pink, yellow, green, brown, danger,
warning
- Zero shadows detected — depth through color contrast only
- Tight display line-heights (1.00) with relaxed body (1.50–1.56)
## 2. Color Palette & Roles
### Primary
- **Revolut Dark** (`#191c1f`): Primary dark surface, button background,
near-black text
- **Pure White** (`#ffffff`): `--rui-color-action-label`, primary light surface
- **Light Surface** (`#f4f4f4`): Secondary button background, subtle surface
### Brand / Interactive
- **Revolut Blue** (`#494fdf`): `--rui-color-blue`, primary brand blue
- **Action Blue** (`#4f55f1`): `--rui-color-action-photo-header-text`, header
accent
- **Blue Text** (`#376cd5`): `--website-color-blue-text`, link blue
### Semantic
- **Danger Red** (`#e23b4a`): `--rui-color-danger`, error/destructive
- **Deep Pink** (`#e61e49`): `--rui-color-deep-pink`, critical accent
- **Warning Orange** (`#ec7e00`): `--rui-color-warning`, warning states
- **Yellow** (`#b09000`): `--rui-color-yellow`, attention
- **Teal** (`#00a87e`): `--rui-color-teal`, success/positive
- **Light Green** (`#428619`): `--rui-color-light-green`, secondary success
- **Green Text** (`#006400`): `--website-color-green-text`, green text
- **Light Blue** (`#007bc2`): `--rui-color-light-blue`, informational
- **Brown** (`#936d62`): `--rui-color-brown`, warm neutral accent
- **Red Text** (`#8b0000`): `--website-color-red-text`, dark red text
### Neutral Scale
- **Mid Slate** (`#505a63`): Secondary text
- **Cool Gray** (`#8d969e`): Muted text, tertiary
- **Gray Tone** (`#c9c9cd`): `--rui-color-grey-tone-20`, borders/dividers
## 3. Typography Rules
### Font Families
- **Display**: `Aeonik Pro` — geometric grotesque, no detected fallbacks
- **Body / UI**: `Inter` — standard system sans
- **Fallback**: `Arial` for specific button contexts
### Hierarchy
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
| --------------- | ---------- | --------------- | ------ | ------------ | -------------- | ------------------- |
| Display Mega | Aeonik Pro | 136px (8.50rem) | 500 | 1.00 (tight) | -2.72px | Stadium-scale hero |
| Display Hero | Aeonik Pro | 80px (5.00rem) | 500 | 1.00 (tight) | -0.8px | Primary hero |
| Section Heading | Aeonik Pro | 48px (3.00rem) | 500 | 1.21 (tight) | -0.48px | Feature sections |
| Sub-heading | Aeonik Pro | 40px (2.50rem) | 500 | 1.20 (tight) | -0.4px | Sub-sections |
| Card Title | Aeonik Pro | 32px (2.00rem) | 500 | 1.19 (tight) | -0.32px | Card headings |
| Feature Title | Aeonik Pro | 24px (1.50rem) | 400 | 1.33 | normal | Light headings |
| Nav / UI | Aeonik Pro | 20px (1.25rem) | 500 | 1.40 | normal | Navigation, buttons |
| Body Large | Inter | 18px (1.13rem) | 400 | 1.56 | -0.09px | Introductions |
| Body | Inter | 16px (1.00rem) | 400 | 1.50 | 0.24px | Standard reading |
| Body Semibold | Inter | 16px (1.00rem) | 600 | 1.50 | 0.16px | Emphasized body |
| Body Bold Link | Inter | 16px (1.00rem) | 700 | 1.50 | 0.24px | Bold links |
### Principles
- **Weight 500 as display default**: Aeonik Pro uses medium (500) for ALL
headings — no bold. This creates authority through size and tracking, not
weight.
- **Billboard tracking**: -2.72px at 136px is extremely compressed — text
designed to be read at a glance, like airport signage.
- **Positive tracking on body**: Inter uses +0.16px to +0.24px, creating airy,
well-spaced reading text that contrasts with the compressed headings.
## 4. Component Stylings
### Buttons
**Primary Dark Pill**
- Background: `#191c1f`
- Text: `#ffffff`
- Padding: 14px 32px
- Radius: 9999px (full pill)
- Hover: opacity 0.85
- Focus: `0 0 0 0.125rem` ring
**Secondary Light Pill**
- Background: `#f4f4f4`
- Text: `#000000`
- Padding: 14px 34px
- Radius: 9999px
- Hover: opacity 0.85
**Outlined Pill**
- Background: transparent
- Text: `#191c1f`
- Border: `2px solid #191c1f`
- Padding: 14px 32px
- Radius: 9999px
**Ghost on Dark**
- Background: `rgba(244, 244, 244, 0.1)`
- Text: `#f4f4f4`
- Border: `2px solid #f4f4f4`
- Padding: 14px 32px
- Radius: 9999px
### Cards & Containers
- Radius: 12px (small), 20px (cards)
- No shadows — flat surfaces with color contrast
- Dark and light section alternation
### Navigation
- Aeonik Pro 20px weight 500
- Clean header, hamburger toggle at 12px radius
- Pill CTAs right-aligned
## 5. Layout Principles
### Spacing System
- Base unit: 8px
- Scale: 4px, 6px, 8px, 14px, 16px, 20px, 24px, 32px, 40px, 48px, 80px, 88px,
120px
- Large section spacing: 80px–120px
### Border Radius Scale
- Standard (12px): Navigation, small buttons
- Card (20px): Feature cards
- Pill (9999px): All buttons
## 6. Depth & Elevation
| Level | Treatment | Use |
| -------------- | --------------------- | -------------------------------------- |
| Flat (Level 0) | No shadow | Everything — Revolut uses zero shadows |
| Focus | `0 0 0 0.125rem` ring | Accessibility focus |
**Shadow Philosophy**: Revolut uses ZERO shadows. Depth comes entirely from the
dark/light section contrast and the generous whitespace between elements.
## 7. Do's and Don'ts
### Do
- Use Aeonik Pro weight 500 for all display headings
- Apply 9999px radius to all buttons — pill shape is universal
- Use generous button padding (14px 32px)
- Keep the palette to near-black + white for marketing surfaces
- Apply positive letter-spacing on Inter body text
### Don't
- Don't use shadows — Revolut is flat by design
- Don't use bold (700) for Aeonik Pro headings — 500 is the weight
- Don't use small buttons — the generous padding is intentional
- Don't apply semantic colors to marketing surfaces — they're for the product
## 8. Responsive Behavior
### Breakpoints
| Name | Width | Key Changes |
| ------------ | ----------- | ---------------------- |
| Mobile Small | <400px | Compact, single column |
| Mobile | 400–720px | Standard mobile |
| Tablet | 720–1024px | 2-column layouts |
| Desktop | 1024–1280px | Standard desktop |
| Large | 1280–1920px | Full layout |
## 9. Agent Prompt Guide
### Quick Color Reference
- Dark: Revolut Dark (`#191c1f`)
- Light: White (`#ffffff`)
- Surface: Light (`#f4f4f4`)
- Blue: Revolut Blue (`#494fdf`)
- Danger: Red (`#e23b4a`)
- Success: Teal (`#00a87e`)
### Example Component Prompts
- "Create a hero: white background. Headline at 136px Aeonik Pro weight 500,
line-height 1.00, letter-spacing -2.72px, #191c1f text. Dark pill CTA
(#191c1f, 9999px, 14px 32px). Outlined pill secondary (transparent, 2px solid
#191c1f)."
- "Build a pill button: #191c1f background, white text, 9999px radius, 14px 32px
padding, 20px Aeonik Pro weight 500. Hover: opacity 0.85."
### Iteration Guide
1. Aeonik Pro 500 for headings — never bold
2. All buttons are pills (9999px) with generous padding
3. Zero shadows — flat is the Revolut identity
4. Near-black + white for marketing, semantic colors for product