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:
#ff385c) as singular brand accent--palette-*) for systematic color management#222222) — warm, not cold#460479) and Plus Magenta (#92174d) for premium tiers#ff385c): --palette-bg-primary-core, primary CTA, brand accent, active states#e00b41): --palette-bg-tertiary-core, pressed/dark variant of brand red#c13515): --palette-text-primary-error, error text on light#b32505): --palette-text-secondary-error-hover, error hover#460479): --palette-bg-primary-luxe, Airbnb Luxe tier branding#92174d): --palette-bg-primary-plus, Airbnb Plus tier branding#222222): --palette-text-primary, primary text — warm, not cold#3f3f3f): --palette-text-focused, focused state text#6a6a6a): Secondary text, descriptionsrgba(0,0,0,0.24)): --palette-text-material-disabled, disabled state#929292): --palette-text-link-disabled, disabled links#428bff): --palette-text-legal, legal links, informational#c1c1c1): Border color for cards and dividers#f2f2f2): Circular navigation buttons, secondary surfaces#ffffff): Page background, card surfacesrgba(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 liftrgba(0,0,0,0.08) 0px 4px 12px): Button hover elevationAirbnb Cereal VF, fallbacks: Circular, -apple-system, system-ui, Roboto, Helvetica Neue"salt" (stylistic alternates) on specific caption elements| 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 |
Primary Dark
#222222 (near-black, not pure black)#ffffffvar(--accent-bg-error)0 0 0 2px var(--palette-grey1000) ring + scale(0.92)Circular Nav
#f2f2f2#222222rgba(0,0,0,0.08) 0px 4px 12px + translateX(50%)#ffffffrgba(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)#222222 textvar(--palette-bg-primary-error) background tint + 0 0 0 2px ring| 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.
#222222 (warm near-black) for text — never pure #000000#ff385c) only for primary CTAs and brand moments — it's the singular accent#000000) for text — always #222222 (warm)--palette-* variables consistently| 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.
#ffffff)#222222)#ff385c)#6a6a6argba(0,0,0,0.24)rgba(0,0,0,0.02) 0px 0px 0px 1px#f2f2f2Airbnb's voice is hospitality made legible — warm, unhurried, grounded in human scale. The anchor phrase is "Belong Anywhere," adopted as the company's official tagline in July 2014 at the same time the Bélo logo launched. That phrase locates the entire voice: not transactional ("Book a room"), not distantly aspirational ("Luxury redefined"), but universal and present-tense. Headlines read like invitations. Error messages read like apologies from someone who genuinely cares. Even legal and safety surfaces preserve the Host-Guest metaphor rather than slipping into corporate passive voice.
| Context | Tone |
|---|---|
| Hero headlines | Warm, inviting, second-person. "Find a place to stay." |
| Listing descriptions | Specific, human-scale. "Sleeps 4" not "Max occupancy: 4". |
| CTAs | Gentle imperative. "Continue", "Reserve", "Send message". Never "Buy now". |
| Host-facing copy | Partnered, respectful. Hosts are capitalized (Host, Superhost), not "providers" or "suppliers". |
| Error messages | Apologetic-but-specific. Explains what happened and how to recover. |
| Onboarding (guest) | Encouraging without being sycophantic. Walks first-time guests through trust features. |
| Trust & Safety copy | Serious but warm. Reads like a thoughtful letter, not a legal document. |
| Marketing long-form | Travel-magazine-editorial. Stories of specific Hosts and Guests. |
Forbidden phrases. "Revolutionary", "disrupt", "next-generation", "game-changer" — the voice is human, not tech-industry. "Book now!" with exclamation — Airbnb treats booking as a trust decision, not a shopping impulse. "Unlock" (as in "Unlock amazing stays") — unlocking is a transactional metaphor and this product is about belonging. Cold-booking vocabulary: "accommodations", "units", "properties" where "homes" works. Scarcity pressure ("Only 2 left!") on product surfaces — this would betray the hospitality thesis.
Airbnb was founded in 2008 in San Francisco by Brian Chesky, Joe Gebbia, and Nathan Blecharczyk. The founding was famously accidental: Chesky and Gebbia couldn't make rent, a design conference was in town, hotels were full, and they put air mattresses in their living room. The first three guests each paid $80 a night. That origin — a home, a Host, a Guest who could not find a traditional place to stay — stayed the company's center of gravity as it grew into a global platform.
In July 2014, Airbnb launched its first major rebrand: the Bélo logo (a universal symbol intended to evoke belonging) and the tagline "Belong Anywhere." Brian Chesky's launch essay framed the thesis directly: "A house is just a space, but a home is where you belong. And what makes this global community so special is that for the very first time, you can belong anywhere." The campaign framed belonging as "the universal human yearning to belong — the desire to feel welcomed, and respected, and appreciated for who you are, no matter where you might be."
That 2014 thesis is still the company's foundation, but the positioning has evolved substantially. In May 2024, the Icons Release introduced a new category — "extraordinary experiences from the world's greatest icons" — with partnerships across sports, music, and film, alongside group-trip features (shared wishlists, a redesigned Messages tab). In 2025, the Summer Release expanded Airbnb into a three-pillar platform — Homes, Experiences, and Services — launching 10 service categories across 260 cities and a curated "Airbnb Originals" line. Brian Chesky framed the shift verbatim: "With the launch of services and experiences, we're changing travel again. Now you can Airbnb more than an Airbnb." The 2025 release shipped with a visual-language refresh toward 3D, skeuomorphic, Pixar-inspired iconography — "vibrant, tactile, and full of depth", with "smooth animations, subtle lighting, soft curves, and drop-shadows" — while deliberately preserving the Cereal typeface, Rausch Red accent, and the underlying Belong-Anywhere thesis. The brand evolved into what Airbnb now frames as an "everything app" without abandoning any of the 2014 foundation.
What Airbnb refuses: the "hotel booking site" aesthetic (stock photography, star ratings as the only trust signal, "Book Now" pressure tactics), the gig-economy aesthetic (minimalist-cold, platform-as-intermediary), and any design choice that would reduce a home to a commodity. What it embraces: photography-first listing cards where the Host's own photos are the hero content, Rausch Red (#ff385c) — named after the company's early office address on Rausch Street, so the brand color is a personal reference rather than a committee decision — generous border-radius that reads as soft rather than precise, and a Bélo logo designed so anyone, anywhere, could draw it.
#222222) text with a whiff of warmth, generous radius throughout. The palette refuses the "cool gray institutional" default of travel-tech.Personas below are fictional archetypes informed by publicly observable Airbnb user segments (leisure travelers, Hosts, long-stay remote workers, multigenerational family travelers), not individual people.
Léa Dubois, 31, Paris. Marketing manager at a fashion startup. Books 4–6 Airbnb stays a year, mostly short European weekends with her partner. Reads listing descriptions carefully; checks the Host's review history before the listing photos. Would rather pay 20% more for a Superhost with a long review history than save money on a new listing. Notices when Airbnb's empty-state copy is warm or cold and judges the product accordingly.
Dimitri Stavros, 58, Thessaloniki. Retired and runs a 2-bedroom Superhost listing in his family's village home. Uses the Host app daily. Values that the Host-facing copy treats him as a partner, not a gig-economy worker. Reads every update to Airbnb's cancellation policies carefully because they affect his household income. Would leave the platform if the Host tools ever felt more extractive than collaborative.
Aisha Mohammed, 27, Cairo. Software engineer working fully remote. Uses Airbnb for 30–90 day "slow travel" stays — Lisbon, Mexico City, Medellín. Filters aggressively for listings with workspace photos and fiber internet mentions. Has written a Medium post about her personal rotation of Superhosts in four cities. Sees Airbnb more as "a distributed home network" than a travel product.
Kenji and Yuki Watanabe, 44 and 41, Yokohama. Family of four. Book 2–3 Airbnb stays per year for multigenerational trips where hotel rooms would require 2–3 separate rooms. Value the "entire home" filter specifically because it lets grandparents and grandchildren share a kitchen. Read reviews filtered by the "Families" tag. Distrust listings that use professional staging photography — they prefer the slightly-imperfect real-Host photos as a trust signal.
| State | Treatment |
|---|---|
| Empty (search, no results) | Single warm line in near-black (#222222): "We couldn't find any homes matching all your filters." One soft-CTA link in Rausch Red: "Clear filters". No illustration. Filter chips visible above so users can adjust in place. |
| Empty (wishlist, first use) | Warm-gray body text: "Save places you love by tapping the heart on any home." One ghost CTA: "Explore homes". No illustration, no sparkles, no tour. |
| Empty (messages, new user) | Near-black headline + warm-gray body: "Your conversations with Hosts will appear here." Nothing more — Airbnb trusts that this becomes obvious once you book. |
| Loading (search results) | Warm-tone skeleton cards preserving the listing-card shape (image area + 3 text lines + price). 1.2s shimmer in a lighter warm tone. Skeletons use the same 12px+ radius as real cards — no geometric surprise on paint-in. |
| Loading (map pan) | Result pins fade at motion-fast as the user drags; map tiles load underneath. No blocking overlay, no "Loading..." text on the map. |
| Error (booking failed) | Warm apology + specific cause + recovery path. "Your booking didn't go through. Please try again, or contact the Host directly." Rausch Red used only on the "Try again" button. Never a bright red banner. |
| Error (form validation) | Field-level. Ultra-thin border switches from warm gray to Rausch Red. 13px warm message below: what's invalid and what would be valid. |
| Error (Host decline) | Warm, explanatory surface. Not framed as failure — framed as "this Host isn't available; here are similar homes". The rejection is never hidden, but the alternative is immediate and present. |
| Success (booking confirmed) | Dedicated confirmation screen. Host's first name + photo + welcome note if they wrote one. Check-in details prominent. Rausch Red only on the "Message Host" button. Past tense: "You're booked." |
| Success (review submitted) | Brief warm-gray inline confirmation: "Thanks for your review." 4s auto-dismiss. No toast spam; reviews are a small ritual, treated quietly. |
| Skeleton | Warm-tone blocks at exact final card dimensions. Shimmer in a lighter warm tone, never cool blue. Photography placeholder is a subtle warm gradient, never a blank gray square — even skeletons respect the photography-first principle. |
| Disabled | Opacity on text and warm-border together. Rausch Red actions become rgba(255,56,92,0.3) — faded warm red, not switched to gray. |
| Loading (Host publishing a listing) | Multi-step progress with named steps ("Photos uploaded", "Description saved", "Calendar synced"). Warm, specific, never abstract "Loading..." text. |
Durations:
| Token | Value | Use |
|---|---|---|
motion-instant | 0ms | State commits, selection, keyboard confirm |
motion-fast | 160ms | Hover, focus, heart-icon toggle, map pin interactions |
motion-standard | 260ms | Sheet, modal, gallery swipe, card expand |
motion-slow | 400ms | Full-screen photo gallery transitions, rare hero reveals |
Easings:
| Token | Curve | Use |
|---|---|---|
ease-enter | cubic-bezier(0.2, 0.6, 0.25, 1) | Arriving — sheets, modals, filter drawers |
ease-exit | cubic-bezier(0.4, 0.0, 1, 1) | Dismissals |
ease-standard | cubic-bezier(0.25, 0.1, 0.25, 1) | Two-way transitions |
ease-warm | cubic-bezier(0.25, 0.8, 0.25, 1) | Heart-icon toggle, Wishlist save — slightly more settled at the end, matching the emotional register of saving a home |
Signature motions.
motion-fast with ease-warm. A small scale pulse (0.9 → 1.05 → 1.0) accompanies the color fill. This is the one place Airbnb's UI allows a tiny "joy" motion — saving a home to come back to later is an emotional act, not a neutral bookmark.motion-standard with ease-standard. No parallax on the photos themselves; the user should feel like they're looking at real photographs, not a marketing carousel.motion-standard with ease-enter. Backdrop fades in synchronously. Dismissal at motion-fast with ease-exit.motion-standard with ease-enter. The pin itself scales 1.0 → 1.15 over motion-fast to confirm selection.prefers-reduced-motion: reduce, all motion-* tokens collapse to motion-instant. The heart-icon pulse becomes an instant color switch. Gallery transitions become cuts. The product stays fully functional; hospitality voice is preserved through copy, not through motion.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, air
Top 14 hex values found in §2 of DESIGN.md, ranked by usage frequency.
A wider example card showing how content sits inside the radius and shadow combination defined by this brand. Card radius is capped at 16px even on pill systems (LINE/Wise/Spotify) so large surfaces stay readable.
Shadow recipes parsed from §6 of DESIGN.md, or default 5-tier scale if none found.