getdesign.mdgetdesign/airbnb

Airbnb

Warm photography-forward marketplace on pure white with iconic Rausch Red accent, rounded Nunito type, and generous three-layer shadows.

install

npx designkit-cli add getdesign/airbnb
source ↗
previewtemplates · Airbnb

Typography

Every text element the kit ships — headings through code

elements

Headings

The quick brown fox

Section heading

Subsection heading

Minor heading

Overline heading

Body text

Lead paragraph.Body text sits at the backbone of any interface — if it reads well, everything else has a chance. If it doesn't, nothing else matters.

Standard paragraph at the body size. Type hierarchies work best when the jump from body to subheading is clear but not disruptive — around 1.25-1.5× works across most contexts. Inline elements like a link, inline code, emphasis, strong, and highlighted text should all feel native to the kit.

Small / caption text — used for metadata, timestamps, descriptions under labels. Usually 14px or slightly smaller.

Lists

Unordered

  • Token-driven styling
  • Agent-readable format
  • Composable kits
    • Colors
    • Typography
    • Component stylings
  • Portable between projects

Ordered

  1. Describe the kit in prose
  2. Extract colors and typography
  3. Apply to a sample UI
  4. Iterate on token values

Blockquote

“Good design is as little design as possible. Less, but better — because it concentrates on the essential aspects, and the products are not burdened with non-essentials.”
— Dieter Rams

Code

// install a kit
$ npx designkit-cli add airbnb

// apply it to your project
import { applyKit } from "@designkit/theme"
applyKit("airbnb")

Rule


Buttons

Primary, secondary, outline, ghost — every state the kit ships

elements

Default

Sizes

With icon

Form fields

Every input control the kit ships — text, select, checkboxes, radios, switches, file

elements

Text inputs

Textarea

Select

Checkboxes

Radio group

Billing cadence

Toggle switch

File input

Feedback

Alerts, badges, progress, tooltips, avatars — the signal surface of every UI

elements

Alerts

!

Scheduled maintenance

We'll be rolling out a new version on Friday at 22:00 UTC. Expect a short read-only window.

!

Kit published

Your DESIGN.md is live. Anyone can now install it with `npx designkit-cli add you/my-kit`.

!

Deprecated API

You're calling /v1/kits which will be removed in 30 days. Migrate to /v2/kits.

!

Build failed

Two component tokens reference an undefined color. Run `designkit lint` to see them.

Badges & tags

OfficialCommunityv2.0BetaDeprecatedOutlineOutline alt

Avatars

JD

Jeremy Dupont

Author

ALMTKPSJ+6

Progress

Upload32%
Build78%
Complete100%

Spinner

Loading…

Tooltip (static)

Tooltip text

Keyboard shortcut

Press K to open the command palette, or Esc to dismiss.

Data display

Table, definition list, empty state — how the kit shows structured data

app

Table

KitAuthorInstallsUpdatedStatus
airbnbgetdesign12.4K2d agoActive
claudegetdesign8.1K5d agoActive
stripegetdesign7.9K1w agoActive
linear.appgetdesign6.2K2w agoBeta
heritagedk2.1K1mo agoDraft

Definition list

Name
Airbnb
Author
getdesign · Claude
Format
DESIGN.md (Google Stitch spec)
Primary font
Nunito (substitute for Airbnb Cereal VF)
Installs
12,408
License
MIT

Empty state

No kits yet

You haven't published any kits on this account. Drop a DESIGN.md in a public repo to get started.

Breadcrumbs

Tabs

Sign in

Centered auth card — the most scrutinised surface in any app

app

Welcome back

Sign in with your work email to continue.

or

New here? Create an account

Dashboard KPIs

Four-card stat row — the staple of every internal dashboard

app

Overview

Performance for the last 30 days

Active users

12,408

+4.2% vs last period

MRR

$28.9K

+12.1% vs last period

Churn

1.8%

-0.3% vs last period

NPS

72

+5 vs last period

[chart placeholder]

Chat thread

Agent + user turn-based chat — bubbles, avatar, timestamp

app
A

Design Agent

online · responds in seconds

Hey — what's the goal of today's session?
I want to ship a pricing page that matches our brand.
Got it. Sharing three variants in a sec — each in your brand tokens so it'll feel native. Which fits better: conversion-first, feature-first, or transparency-first?
Let's try conversion-first.

Hero

Landing-page headline + subtitle + primary CTA

marketing
New · v2.0

Designed for humans. Built for agents.

Ship a brand-aligned product in hours. Coding agents write UI that matches your design system — no brief, no handoff.

Pricing

Three-tier comparison grid with a highlighted middle tier

marketing

Simple pricing

Pay for what you use. Change plans any time.

Hobby

$0forever
  • 1 project
  • Community support
  • Public kits only

Pro

Popular
$19per month
  • Unlimited projects
  • Private kits
  • Priority support
  • AI kit generator

Team

$49per seat / mo
  • Everything in Pro
  • Shared workspace
  • SSO + audit logs
  • Dedicated support

source

---
name: Airbnb
description:
  Warm photography-forward marketplace on pure white with iconic Rausch Red
  accent, rounded Nunito type, and generous three-layer shadows.
originalFonts:
  primary: "Airbnb Cereal VF"
  fallbacks:
    - "Circular"
    - "-apple-system"
    - "system-ui"
    - "Roboto"
    - "Helvetica Neue"
colors:
  background: "#ffffff"
  surface: "#ffffff"
  surface-raised: "#f2f2f2"
  ink: "#222222"
  ink-muted: "#6a6a6a"
  accent: "#ff385c"
  accent-alt: "#e00b41"
  border: "#c1c1c1"
  link: "#428bff"
  danger: "#c13515"
  rausch-red: "#ff385c"
  deep-rausch: "#e00b41"
  error-red: "#c13515"
  error-dark: "#b32505"
  luxe-purple: "#460479"
  plus-magenta: "#92174d"
  near-black: "#222222"
  focused-gray: "#3f3f3f"
  secondary-gray: "#6a6a6a"
  link-disabled: "#929292"
  legal-blue: "#428bff"
  border-gray: "#c1c1c1"
  light-surface: "#f2f2f2"
  pure-white: "#ffffff"
typography:
  h1:
    family: "Nunito"
    size: "1.75rem"
    weight: 700
    lineHeight: 1.43
  h2:
    family: "Nunito"
    size: "1.38rem"
    weight: 600
    lineHeight: 1.18
  h3:
    family: "Nunito"
    size: "1.25rem"
    weight: 600
    lineHeight: 1.2
  body:
    family: "Nunito"
    size: "0.88rem"
    weight: 400
    lineHeight: 1.43
  button:
    family: "Nunito"
    size: "1rem"
    weight: 500
    lineHeight: 1.25
  caption:
    family: "Nunito"
    size: "0.75rem"
    weight: 400
    lineHeight: 1.33
spacing:
  xs: "0.5rem"
  sm: "0.75rem"
  md: "1rem"
  lg: "1.5rem"
  xl: "2rem"
rounded:
  sm: "4px"
  md: "8px"
  lg: "20px"
  xl: "32px"
shadows:
  sm: "rgba(0,0,0,0.02) 0px 0px 0px 1px"
  md:
    "rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px,
    rgba(0,0,0,0.1) 0px 4px 8px"
  lg: "rgba(0,0,0,0.08) 0px 4px 12px"
components:
  button-primary:
    background: "{colors.ink}"
    color: "#ffffff"
    border: "1px solid {colors.ink}"
    radius: "{rounded.md}"
    padding: "0 24px"
  button-secondary:
    background: "{colors.surface-raised}"
    color: "{colors.ink}"
    border: "1px solid {colors.border}"
    radius: "50%"
    padding: "0.5rem"
  card:
    background: "{colors.surface}"
    border: "1px solid {colors.border}"
    radius: "{rounded.lg}"
    padding: "1.5rem"
  input:
    background: "{colors.surface}"
    color: "{colors.ink}"
    border: "1px solid {colors.border}"
    radius: "{rounded.md}"
    padding: "0.5rem 0.75rem"
---

<!-- source: VoltAgent/awesome-design-md @ 80bbbc2 (MIT) — see ATTRIBUTION.md -->

# Design System Inspiration of Airbnb

## 1. Visual Theme & Atmosphere

Airbnb's website is a warm, photography-forward marketplace that feels like
flipping through a travel magazine where every page invites you to book. The
design operates on a foundation of pure white (`#ffffff`) with the iconic Rausch
Red (`#ff385c`) — named after Airbnb's first street address — serving as the
singular brand accent. The result is a clean, airy canvas where listing
photography, category icons, and the red CTA button are the only sources of
color.

The typography uses Airbnb Cereal VF — a custom variable font that's warm and
approachable, with rounded terminals that echo the brand's "belong anywhere"
philosophy. The font operates in a tight weight range: 500 (medium) for most UI,
600 (semibold) for emphasis, and 700 (bold) for primary headings. Slight
negative letter-spacing (-0.18px to -0.44px) on headings creates a cozy,
intimate reading experience rather than the compressed efficiency of tech
companies.

What distinguishes Airbnb is its palette-based token system (`--palette-*`) and
multi-layered shadow approach. The primary card shadow uses a three-layer stack
(`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`)
that creates a subtle, warm lift. Combined with generous border-radius
(8px–32px), circular navigation controls (50%), and a category pill bar with
horizontal scrolling, the interface feels tactile and inviting — designed for
browsing, not commanding.

**Key Characteristics:**

- Pure white canvas with Rausch Red (`#ff385c`) as singular brand accent
- Airbnb Cereal VF — custom variable font with warm, rounded terminals
- Palette-based token system (`--palette-*`) for systematic color management
- Three-layer card shadows: border ring + soft blur + stronger blur
- Generous border-radius: 8px buttons, 14px badges, 20px cards, 32px large
  elements
- Circular navigation controls (50% radius)
- Photography-first listing cards — images are the hero content
- Near-black text (`#222222`) — warm, not cold
- Luxe Purple (`#460479`) and Plus Magenta (`#92174d`) for premium tiers

## 2. Color Palette & Roles

### Primary Brand

- **Rausch Red** (`#ff385c`): `--palette-bg-primary-core`, primary CTA, brand
  accent, active states
- **Deep Rausch** (`#e00b41`): `--palette-bg-tertiary-core`, pressed/dark
  variant of brand red
- **Error Red** (`#c13515`): `--palette-text-primary-error`, error text on light
- **Error Dark** (`#b32505`): `--palette-text-secondary-error-hover`, error
  hover

### Premium Tiers

- **Luxe Purple** (`#460479`): `--palette-bg-primary-luxe`, Airbnb Luxe tier
  branding
- **Plus Magenta** (`#92174d`): `--palette-bg-primary-plus`, Airbnb Plus tier
  branding

### Text Scale

- **Near Black** (`#222222`): `--palette-text-primary`, primary text — warm, not
  cold
- **Focused Gray** (`#3f3f3f`): `--palette-text-focused`, focused state text
- **Secondary Gray** (`#6a6a6a`): Secondary text, descriptions
- **Disabled** (`rgba(0,0,0,0.24)`): `--palette-text-material-disabled`,
  disabled state
- **Link Disabled** (`#929292`): `--palette-text-link-disabled`, disabled links

### Interactive

- **Legal Blue** (`#428bff`): `--palette-text-legal`, legal links, informational
- **Border Gray** (`#c1c1c1`): Border color for cards and dividers
- **Light Surface** (`#f2f2f2`): Circular navigation buttons, secondary surfaces

### Surface & Shadows

- **Pure White** (`#ffffff`): Page background, card surfaces
- **Card Shadow**
  (`rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`):
  Three-layer warm lift
- **Hover Shadow** (`rgba(0,0,0,0.08) 0px 4px 12px`): Button hover elevation

## 3. Typography Rules

### Font Family

- **Primary**: `Airbnb Cereal VF`, fallbacks:
  `Circular, -apple-system, system-ui, Roboto, Helvetica Neue`
- **OpenType Features**: `"salt"` (stylistic alternates) on specific caption
  elements

### Hierarchy

| Role                | Font             | Size           | Weight  | Line Height  | Letter Spacing | Notes                       |
| ------------------- | ---------------- | -------------- | ------- | ------------ | -------------- | --------------------------- |
| Section Heading     | Airbnb Cereal VF | 28px (1.75rem) | 700     | 1.43         | normal         | Primary headings            |
| Card Heading        | Airbnb Cereal VF | 22px (1.38rem) | 600     | 1.18 (tight) | -0.44px        | Category/card titles        |
| Card Heading Medium | Airbnb Cereal VF | 22px (1.38rem) | 500     | 1.18 (tight) | -0.44px        | Lighter variant             |
| Sub-heading         | Airbnb Cereal VF | 21px (1.31rem) | 700     | 1.43         | normal         | Bold sub-headings           |
| Feature Title       | Airbnb Cereal VF | 20px (1.25rem) | 600     | 1.20 (tight) | -0.18px        | Feature headings            |
| UI Medium           | Airbnb Cereal VF | 16px (1.00rem) | 500     | 1.25 (tight) | normal         | Nav, emphasized text        |
| UI Semibold         | Airbnb Cereal VF | 16px (1.00rem) | 600     | 1.25 (tight) | normal         | Strong emphasis             |
| Button              | Airbnb Cereal VF | 16px (1.00rem) | 500     | 1.25 (tight) | normal         | Button labels               |
| Body / Link         | Airbnb Cereal VF | 14px (0.88rem) | 400     | 1.43         | normal         | Standard body               |
| Body Medium         | Airbnb Cereal VF | 14px (0.88rem) | 500     | 1.29 (tight) | normal         | Medium body                 |
| Caption Salt        | Airbnb Cereal VF | 14px (0.88rem) | 600     | 1.43         | normal         | `"salt"` feature            |
| Small               | Airbnb Cereal VF | 13px (0.81rem) | 400     | 1.23 (tight) | normal         | Descriptions                |
| Tag                 | Airbnb Cereal VF | 12px (0.75rem) | 400–700 | 1.33         | normal         | Tags, prices                |
| Badge               | Airbnb Cereal VF | 11px (0.69rem) | 600     | 1.18 (tight) | normal         | `"salt"` feature            |
| Micro Uppercase     | Airbnb Cereal VF | 8px (0.50rem)  | 700     | 1.25 (tight) | 0.32px         | `text-transform: uppercase` |

### Principles

- **Warm weight range**: 500–700 dominate. No weight 300 or 400 for headings —
  Airbnb's type is always at least medium weight, creating a warm, confident
  voice.
- **Negative tracking on headings**: -0.18px to -0.44px letter-spacing on
  display creates intimate, cozy headings rather than cold, compressed ones.
- **"salt" OpenType feature**: Stylistic alternates on specific UI elements
  (badges, captions) create subtle glyph variations that add visual interest.
- **Variable font precision**: Cereal VF enables continuous weight
  interpolation, though the design system uses discrete stops at 500, 600,
  and 700.

## 4. Component Stylings

### Buttons

**Primary Dark**

- Background: `#222222` (near-black, not pure black)
- Text: `#ffffff`
- Padding: 0px 24px
- Radius: 8px
- Hover: transitions to error/brand accent via `var(--accent-bg-error)`
- Focus: `0 0 0 2px var(--palette-grey1000)` ring + scale(0.92)

**Circular Nav**

- Background: `#f2f2f2`
- Text: `#222222`
- Radius: 50% (circle)
- Hover: shadow `rgba(0,0,0,0.08) 0px 4px 12px` + translateX(50%)
- Active: 4px white border ring + focus shadow
- Focus: scale(0.92) shrink animation

### Cards & Containers

- Background: `#ffffff`
- Radius: 14px (badges), 20px (cards/buttons), 32px (large)
- Shadow:
  `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px`
  (three-layer)
- Listing cards: full-width photography on top, details below
- Carousel controls: circular 50% buttons

### Inputs

- Search: `#222222` text
- Focus: `var(--palette-bg-primary-error)` background tint + `0 0 0 2px` ring
- Radius: depends on context (search bar uses pill-like rounding)

### Navigation

- White sticky header with search bar centered
- Airbnb logo (Rausch Red) left-aligned
- Category filter pills: horizontal scroll below search
- Circular nav controls for carousel navigation
- "Become a Host" text link, avatar/menu right-aligned

### Image Treatment

- Listing photography fills card top with generous height
- Image carousel with dot indicators
- Heart/wishlist icon overlay on images
- 8px–14px radius on contained images

## 5. Layout Principles

### Spacing System

- Base unit: 8px
- Scale: 2px, 3px, 4px, 6px, 8px, 10px, 11px, 12px, 15px, 16px, 22px, 24px, 32px

### Grid & Container

- Full-width header with centered search
- Category pill bar: horizontal scrollable row
- Listing grid: responsive multi-column (3–5 columns on desktop)
- Full-width footer with link columns

### Whitespace Philosophy

- **Travel-magazine spacing**: Generous vertical padding between sections
  creates a leisurely browsing pace — you're meant to scroll slowly, like
  browsing a magazine.
- **Photography density**: Listing cards are packed relatively tightly, but each
  image is large enough to feel immersive.
- **Search bar prominence**: The search bar gets maximum vertical space in the
  header — finding your destination is the primary action.

### Border Radius Scale

- Subtle (4px): Small links
- Standard (8px): Buttons, tabs, search elements
- Badge (14px): Status badges, labels
- Card (20px): Feature cards, large buttons
- Large (32px): Large containers, hero elements
- Circle (50%): Nav controls, avatars, icons

## 6. Depth & Elevation

| Level                  | Treatment                                                                                     | Use                            |
| ---------------------- | --------------------------------------------------------------------------------------------- | ------------------------------ |
| Flat (Level 0)         | No shadow                                                                                     | Page background, text blocks   |
| Card (Level 1)         | `rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px, rgba(0,0,0,0.1) 0px 4px 8px` | Listing cards, search bar      |
| Hover (Level 2)        | `rgba(0,0,0,0.08) 0px 4px 12px`                                                               | Button hover, interactive lift |
| Active Focus (Level 3) | `rgb(255,255,255) 0px 0px 0px 4px` + focus ring                                               | Active/focused elements        |

**Shadow Philosophy**: Airbnb's three-layer shadow system creates a warm,
natural lift. Layer 1 (`0px 0px 0px 1px` at 0.02 opacity) is an ultra-subtle
border. Layer 2 (`0px 2px 6px` at 0.04) provides soft ambient shadow. Layer 3
(`0px 4px 8px` at 0.1) adds the primary lift. This graduated approach creates
shadows that feel like natural light rather than CSS effects.

## 7. Do's and Don'ts

### Do

- Use `#222222` (warm near-black) for text — never pure `#000000`
- Apply Rausch Red (`#ff385c`) only for primary CTAs and brand moments — it's
  the singular accent
- Use Airbnb Cereal VF at weight 500–700 — the warm weight range is intentional
- Apply the three-layer card shadow for all elevated surfaces
- Use generous border-radius: 8px for buttons, 20px for cards, 50% for controls
- Use photography as the primary visual content — listings are image-first
- Apply negative letter-spacing (-0.18px to -0.44px) on headings for intimacy
- Use circular (50%) buttons for carousel/navigation controls

### Don't

- Don't use pure black (`#000000`) for text — always `#222222` (warm)
- Don't apply Rausch Red to backgrounds or large surfaces — it's an accent only
- Don't use thin font weights (300, 400) for headings — 500 minimum
- Don't use heavy shadows (>0.1 opacity as primary layer) — keep them warm and
  graduated
- Don't use sharp corners (0–4px) on cards — the generous rounding (20px+) is
  core
- Don't introduce additional brand colors beyond the Rausch/Luxe/Plus system
- Don't override the palette token system — use `--palette-*` variables
  consistently

## 8. Responsive Behavior

### Breakpoints

| Name          | Width       | Key Changes                   |
| ------------- | ----------- | ----------------------------- |
| Mobile Small  | <375px      | Single column, compact search |
| Mobile        | 375–550px   | Standard mobile listing grid  |
| Tablet Small  | 550–744px   | 2-column listings             |
| Tablet        | 744–950px   | Search bar expansion          |
| Desktop Small | 950–1128px  | 3-column listings             |
| Desktop       | 1128–1440px | 4-column grid, full header    |
| Large Desktop | 1440–1920px | 5-column grid                 |
| Ultra-wide    | >1920px     | Maximum grid width            |

_Note: Airbnb has 61 detected breakpoints — one of the most granular responsive
systems observed, reflecting their obsession with layout at every possible
screen size._

### Touch Targets

- Circular nav buttons: adequate 50% radius sizing
- Listing cards: full-card tap target on mobile
- Search bar: prominently sized for thumb interaction
- Category pills: horizontally scrollable with generous padding

### Collapsing Strategy

- Listing grid: 5 → 4 → 3 → 2 → 1 columns
- Search: expanded bar → compact bar → overlay
- Category pills: horizontal scroll at all sizes
- Navigation: full header → mobile simplified
- Map: side panel → overlay/toggle

### Image Behavior

- Listing photos: carousel with swipe on mobile
- Responsive image sizing with aspect ratio maintained
- Heart overlay positioned consistently across sizes
- Photo quality adjusts based on viewport

## 9. Agent Prompt Guide

### Quick Color Reference

- Background: Pure White (`#ffffff`)
- Text: Near Black (`#222222`)
- Brand accent: Rausch Red (`#ff385c`)
- Secondary text: `#6a6a6a`
- Disabled: `rgba(0,0,0,0.24)`
- Card border: `rgba(0,0,0,0.02) 0px 0px 0px 1px`
- Card shadow: full three-layer stack
- Button surface: `#f2f2f2`

### Example Component Prompts

- "Create a listing card: white background, 20px radius. Three-layer shadow:
  rgba(0,0,0,0.02) 0px 0px 0px 1px, rgba(0,0,0,0.04) 0px 2px 6px,
  rgba(0,0,0,0.1) 0px 4px 8px. Photo area on top (16:10 ratio), details below:
  16px Airbnb Cereal VF weight 600 title, 14px weight 400 description in
  #6a6a6a."
- "Design search bar: white background, full card shadow, 32px radius on
  container. Search text at 14px Cereal VF weight 400. Red search button
  (#ff385c, 50% radius, white icon)."
- "Build category pill bar: horizontal scrollable row. Each pill: 14px Cereal VF
  weight 600, #222222 text, bottom border on active. Circular prev/next arrows
  (#f2f2f2 bg, 50% radius)."
- "Create a CTA button: #222222 background, white text, 8px radius, 16px Cereal
  VF weight 500, 0px 24px padding. Hover: brand red accent."
- "Design a heart/wishlist button: transparent background, 50% radius, white
  heart icon with dark shadow outline."

### Iteration Guide

1. Start with white — the photography provides all the color
2. Rausch Red (#ff385c) is the singular accent — use sparingly for CTAs only
3. Near-black (#222222) for text — the warmth matters
4. Three-layer shadows create natural, warm lift — always use all three layers
5. Generous radius: 8px buttons, 20px cards, 50% controls
6. Cereal VF at 500–700 weight — no thin weights for any heading
7. Photography is hero — every listing card is image-first