Supabase — Design System
Supabase is daylight engineering: a near-white #FCFCFC canvas, near-black ink, and one signature green (#72E3AD on the primary button) that always means 'go'. Manrope carries the whole site at medium weights — a 46px H1 that stays humble, 15px working text, tight 6px corners everywhere. Color is functional, not decorative: green for actions, gray for chrome, syntax colors only inside real code blocks. Sections breathe with generous whitespace while the content itself stays dense and technical. It reads like a database console that learned to breathe — bright, precise, quietly confident.
This is a static, crawlable rendering for search & AI engines. The interactive version — filters, live decode console, copy & export — is at https://mozaika.design/ds/supabase.
Tokens
Supabase's decoded design system: background #FCFCFC, text #171717, accent #72E3AD, link #50C896, primary #72E3AD; type scale h1 46px / h2 16px / body 15px; 8px spacing base; 0px base radius. The single interactive/action color is #72E3AD — used only on interactive or must-notice elements (buttons, links, key highlights), never on large fills.
Color roles
| Role | Value |
|---|---|
| bg | #FCFCFC |
| surface | #EEEEEE |
| border | #D9D9D9 |
| text | #171717 |
| text_muted | #6E6E6E |
| primary | #72E3AD |
| accent | #72E3AD |
| link | #50C896 |
| button_bg | #72E3AD |
| button_text | #171717 |
Using these colors
- Action color
#72E3AD— the single interactive color; only on things you click or must notice, never large fills. primary,accent,button_bgare all#72E3AD— one role, not several (the action color).- accent
#72E3AD— THE accent / action color — interactive & must-notice only (buttons, links, focus, one key highlight); never large fills or backgrounds. Scarcity is what makes it read as designed. - link
#50C896— fails contrast on the background (~2.0:1) — this is a dark UI color, NOT a readable link; use the text or action color for links (verify against the reference).
Typography
- Heading: Manrope
- Body: Manrope
- h1: 46px
- h2: 16px
- body: 15px
Spacing
- base unit: 8px
- scale: 4px, 8px, 12px, 16px, 24px, 32px, 48px, 64px
Radii
- base: 0px
- button: 6px
Per-section tokens (46)
- Hero — light · bg #FDFDFD · text #636564 · 1 col · center
- Hero — light · bg #FFFFFF · text #B6CEC3 · 2 col · left
- Hero — light · bg #FDFDFD · text #D9DEDC · 3 col · split
- Hero — light · bg #FDFDFD · text #7E8280 · 2 col · split
- Pricing / Plans — light · bg #FDFDFD · text #CFD5D3 · 3 col · split
- Hero — light · bg #FDFDFD · text #828785 · 3 col · split
- Feature — light · bg #FFFFFF · text #D1D2D2 · 4 col · split
- Feature — light · bg #FFFFFF · text #8B8C8B · 4 col · split
- Feature — light · bg #FFFFFF · text #959595 · 3 col · split
- Bento Grid — light · bg #F3F3F3 · text #BAC5C0 · 2 col · split
- Feature — light · bg #FDFDFD · text #EBEBEC · 3 col · split
- Feature — light · bg #FFFFFF · text #C2C3C2 · 1 col · left
- Testimonial / Social Proof — light · bg #FDFDFD · text #5E5E5E · 1 col · left
- Gallery / Showcase — light · bg #FDFDFD · text #DCE0DE · 3 col · split
- Testimonial / Social Proof — light · bg #FFFFFF · text #A4ADAA · 2 col · split
- Logo Wall — light · bg #FDFDFD · text #3B3B3B · 2 col · split
- Comparison — light · bg #FFFFFF · text #BECBC5 · 1 col · left
- Testimonial / Social Proof — light · bg #FFFFFF · text #D3D4D3 · 3 col · split
- Feature — light · bg #FDFDFD · text #DADCDB · 2 col · split
- Gallery / Showcase — light · bg #FDFDFD · text #C2CEC8 · 2 col · split
- Feature — light · bg #FFFFFF · text #8E8E8E · 3 col · split
- Testimonial / Social Proof — light · bg #FFFFFF · text #BEBFBF · 3 col · split
- Feature — light · bg #FDFDFD · text #B9B9B9 · 2 col · split
- Feature — light · bg #FDFDFD · text #C6C7C6 · 2 col · split
- Feature — light · bg #FDFDFD · text #D6D7D6 · 3 col · split
- Banner — light · bg #FDFDFD · text #9E9E9D · 1 col · left
- Feature — light · bg #FFFFFF · text #939393 · 3 col · split
- Gallery / Showcase — light · bg #FDFDFD · text #A1A1A1 · 2 col · split
- Comparison — light · bg #FDFDFD · text #DEDEDE · 2 col · split
- Feature — light · bg #FDFDFD · text #A0A0A0 · 2 col · split
- Feature — light · bg #FDFDFD · text #D3D5D4 · 2 col · split
- Feature — light · bg #FFFFFF · text #9B9D9D · 3 col · split
- Feature — light · bg #FDFDFD · text #8D8D8D · 2 col · split
- FAQ — light · bg #FDFDFD · text #D1D3D5 · 2 col · split
- Feature — light · bg #FDFDFD · text #E0E0E0 · 1 col · left
- Gallery / Showcase — light · bg #FDFDFD · text #D9E0DD · 1 col · left
- CTA / Sign-up — light · bg #FDFDFD · text #606261 · 1 col · left
- Feature — light · bg #FFFFFF · text #8E8E8E · 3 col · split
- Testimonial / Social Proof — light · bg #FFFFFF · text #CECED1 · 3 col · split
- CTA / Sign-up — light · bg #FDFDFD · text #9A9F9C · 2 col · split
- Footer — light · bg #FDFDFD · text #BBBEBC · 1 col · left
- Gallery / Showcase — light · bg #FDFDFD · text #D2D6D4 · 2 col · split
- CTA / Sign-up — light · bg #FDFDFD · text #888C8A · 3 col · split
- Gallery / Showcase — light · bg #FDFDFD · text #D9E0DD · 1 col · left
- CTA / Sign-up — light · bg #FDFDFD · text #A6A8A7 · 2 col · split
- CTA / Sign-up — light · bg #FDFDFD · text #9A9C9B · 1 col · left
Export: DESIGN.md
# Supabase — Design System > light, modern, medium, tailwind Supabase is daylight engineering: a near-white #FCFCFC canvas, near-black ink, and one signature green (#72E3AD on the primary button) that always means 'go'. Manrope carries the whole site at medium weights — a 46px H1 that stays humble, 15px working text, tight 6px corners everywhere. Color is functional, not decorative: green for actions, gray for chrome, syntax colors only inside real code blocks. Sections breathe with generous whitespace while the content itself stays dense and technical. It reads like a database console that learned to breathe — bright, precise, quietly confident. ## Colors | Role | Value | |------|-------| | bg | `#FCFCFC` | | surface | `#EEEEEE` | | border | `#D9D9D9` | | text | `#171717` | | text_muted | `#6E6E6E` | | primary | `#72E3AD` | | accent | `#72E3AD` | | link | `#50C896` | | button_bg | `#72E3AD` | | button_text | `#171717` | **Using these colors** - **Action color** `#72E3AD` — the single interactive color; it appears only on things you click or must notice (buttons, key highlights), never on large fills or backgrounds. - `primary`, `accent`, `button_bg` are all `#72E3AD` — one role, not several (your action color). - **accent** `#72E3AD` — THE accent / action color — interactive & must-notice only (buttons, links, focus, one key highlight); never large fills or backgrounds. Scarcity is what makes it read as designed. - **link** `#50C896` — fails contrast on the background (~2.0:1) — this is a dark UI color, NOT a readable link; use the text or action color for links (verify against the reference). ## Typography - Heading: **Manrope** - Body: **Manrope** | Role | Size / weight · line-height · tracking | |------|------------------------------------------| | hero | 46px / 500 · lh 46px | | h2 | 34px / 600 · lh 38px | | h3 | 22px / 450 · lh 30px | | body | 15px / 450 · lh 23px | | small | 14px / 450 · lh 20px | - Weight ladder: 450 · 500 · 600 — use these exact measured weights, not the 400/600 defaults. > **Fonts —** Manrope — free, on Google. ## Spacing - base unit: 8px - scale: 4px, 8px, 12px, 16px, 24px, 32px, 48px, 64px - section rhythm: 96px top/bottom padding per section (measured) ## Radius - base: 0px - button: 6px - card: 8px - pill: 9999px ## Primary button - bg `#72E3AD` · text `#171717` · radius 6px ## How to apply Paste the Tailwind `@theme` (or CSS variables) as your base, then build each section to its spec — verify every color, radius, and font against these tokens.
Export: Tailwind v4 (@theme)
@theme {
/* action color #72E3AD — the one interactive color; buttons/links/emphasis only, never large fills. */
--color-bg: #FCFCFC;
--color-surface: #EEEEEE;
--color-border: #D9D9D9;
--color-text: #171717;
--color-text-muted: #6E6E6E;
--color-primary: #72E3AD; /* primary brand / action color. */
--color-accent: #72E3AD; /* THE accent / action color — interactive & must-notice only (buttons, links, focus, one key highlight); never large fills or backgrounds. Scarcity is what makes it read as designed. */
--color-link: #50C896; /* fails contrast on the background (~2.0:1) — this is a dark UI color, NOT a readable link; use the text or action color for links (verify against the reference). */
--color-button-bg: #72E3AD; /* primary-button fill — the main call-to-action color. */
--color-button-text: #171717;
/* fonts: Manrope — free, on Google. */
--font-heading: "Manrope", system-ui, -apple-system, 'Segoe UI', sans-serif;
--font-body: "Manrope", system-ui, -apple-system, 'Segoe UI', sans-serif;
/* measured weights: 450, 500, 600 — use these, not 400/600 */
--text-hero: 46px; --font-weight-hero: 500; --leading-hero: 46px;
--text-h2: 34px; --font-weight-h2: 600; --leading-h2: 38px;
--text-h3: 22px; --font-weight-h3: 450; --leading-h3: 30px;
--text-body: 15px; --font-weight-body: 450; --leading-body: 23px;
--text-small: 14px; --font-weight-small: 450; --leading-small: 20px;
--radius-base: 0px;
--radius-button: 6px;
--radius-card: 8px;
--radius-pill: 9999px;
--section-y: 96px; /* per-section vertical padding (measured) */
--spacing-1: 4px;
--spacing-2: 8px;
--spacing-3: 12px;
--spacing-4: 16px;
--spacing-5: 24px;
--spacing-6: 32px;
--spacing-7: 48px;
--spacing-8: 64px;
}Export: CSS variables
:root {
/* action color #72E3AD — the one interactive color; buttons/links/emphasis only, never large fills. */
--bg: #FCFCFC;
--surface: #EEEEEE;
--border: #D9D9D9;
--text: #171717;
--text-muted: #6E6E6E;
--primary: #72E3AD; /* primary brand / action color. */
--accent: #72E3AD; /* THE accent / action color — interactive & must-notice only (buttons, links, focus, one key highlight); never large fills or backgrounds. Scarcity is what makes it read as designed. */
--link: #50C896; /* fails contrast on the background (~2.0:1) — this is a dark UI color, NOT a readable link; use the text or action color for links (verify against the reference). */
--button-bg: #72E3AD; /* primary-button fill — the main call-to-action color. */
--button-text: #171717;
--font-heading: "Manrope", system-ui, -apple-system, 'Segoe UI', sans-serif;
--font-body: "Manrope", system-ui, -apple-system, 'Segoe UI', sans-serif;
--text-hero: 46px; --weight-hero: 500; --leading-hero: 46px;
--text-h2: 34px; --weight-h2: 600; --leading-h2: 38px;
--text-h3: 22px; --weight-h3: 450; --leading-h3: 30px;
--text-body: 15px; --weight-body: 450; --leading-body: 23px;
--text-small: 14px; --weight-small: 450; --leading-small: 20px;
--radius: 0px;
--radius-button: 6px;
--radius-card: 8px;
--radius-pill: 9999px;
--section-y: 96px;
}
/* fonts: Manrope — free, on Google. */