Best For
macOS / 原生 / 暗色
macOS Vibrancy
Native macOS dark vibrancy style. Multi-layer dark gray panels, system-level backdrop-blur, and extreme restraint create the calm, professional feel of a desktop application.
Best For
macOS / 原生 / 暗色
Primary Move
Use three-depth dark gray system: #1c1c1e (deepest) -> #2c2c2e -> #3a3a3c (lightest)
Watch Out
No gradients on any element (backgrounds are solid dark grays)
Showcase Entry
Live preview of the showcase page. Click to explore the full experience.
Color Palette
Primary
#3a3a3c
Secondary
#1c1c1e
Accent 1
#0a84ff
Accent 2
#30d158
Prompts
Use one-click prompts to generate macOS 毛玻璃 style UIs. Hard mode enforces strict constraints; soft mode keeps overall style direction while allowing flexibility.
Strict constraints for high style consistency
STYLEKIT_STYLE_REFERENCE
style_name: macOS 毛玻璃
style_slug: macos-vibrancy
style_source: /styles/macos-vibrancy
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# macOS Vibrancy (macOS 毛玻璃) Design System
> macOS 原生暗色毛玻璃风格。通过多层深灰面板、系统级 backdrop-blur 和极度克制的装饰,还原桌面应用的沉稳质感。
## 核心理念
macOS Vibrancy 是 Apple 桌面应用设计语言的 Web 还原。它的核心不是炫技,而是克制。
核心理念:
- 层级即色彩:不用渐变和发光,纯靠背景深浅区分层级(#1c1c1e -> #2c2c2e -> #3a3a3c)
- 系统级模糊:侧边栏使用 backdrop-blur 让底层内容微微透出,模拟 NSVisualEffectView
- 排版驱动:衬线标题 + 无衬线正文 + 等宽代码,三种字体各司其职
- 1px 哲学:所有分隔都是 1px 半透明边框,不用阴影制造深度
- 无装饰主义:没有渐变、没有发光、没有动画,内容本身就是装饰
设计原则:
- 视觉一致性:所有组件必须遵循统一的视觉语言,从色彩到字体到间距保持谐调
- 层次分明:通过颜色深浅、字号大小、留白空间建立清晰的信息层级
- 交互反馈:每个可交互元素都必须有明确的 hover、active、focus 状态反馈
- 响应式适配:设计必须在移动端、平板、桌面端上保持一致的体验
- 无障碍性:确保色彩对比度符合 WCAG 2.1 AA 标准,所有交互元素可键盘访问
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border
颜色: border-white/10
圆角: rounded-xl
```
### 阴影
```
小: shadow-none
中: shadow-[0_1px_0_rgba(255,255,255,0.05)]
大: shadow-[0_2px_8px_rgba(0,0,0,0.3)]
悬停: hover:shadow-none
聚焦: focus:shadow-[0_0_0_2px_rgba(100,100,255,0.3)]
```
### 交互效果
```
悬停位移: undefined
过渡动画: transition-colors duration-200 ease-out
按下状态: active:opacity-80
```
### 字体
```
标题: font-serif font-semibold text-white/95
正文: text-white/70
```
### 字号
```
Hero: text-3xl md:text-5xl
H1: text-2xl md:text-4xl
H2: text-xl md:text-2xl
H3: text-lg md:text-xl
正文: text-sm
小字: text-xs
```
### 间距
```
Section: py-12 md:py-16
容器: px-4 md:px-6
卡片: p-4 md:p-6
```
---
## [FORBIDDEN] 绝对禁止
以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:
### 禁止的 Class
- `bg-gradient-to-r`
- `bg-gradient-to-br`
- `bg-gradient-to-l`
- `shadow-xl`
- `shadow-2xl`
- `shadow-lg`
- `rounded-3xl`
- `rounded-full`
- `text-yellow-400`
- `text-pink-500`
- `text-green-400`
- `animate-pulse`
- `animate-bounce`
- `border-2`
- `border-4`
### 禁止的模式
- 匹配 `^bg-gradient`
- 匹配 `^shadow-(xl|2xl|lg)$`
- 匹配 `^rounded-(3xl|full)$`
- 匹配 `^animate-`
- 匹配 `^border-[2-9]$`
### 禁止原因
- `bg-gradient-to-r`: macOS Vibrancy uses solid dark backgrounds, not gradients
- `shadow-xl`: macOS Vibrancy uses minimal shadows, depth comes from background layers
- `rounded-3xl`: macOS Vibrancy uses moderate rounding (rounded-lg to rounded-xl)
- `animate-pulse`: macOS Vibrancy avoids decorative animations
- `border-2`: macOS Vibrancy uses 1px borders only
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
bg-[#3a3a3c] text-white/90
rounded-lg
transition-colors duration-200
```
### 卡片必须包含
```
bg-[#2c2c2e]
border border-white/8
rounded-xl
```
### 输入框必须包含
```
bg-[#1c1c1e]
border border-white/10
rounded-lg
text-white/90 placeholder-white/30
focus:outline-none focus:border-white/25
transition-colors duration-200
```
---
## [COMPARE] 错误 vs 正确对比
### 按钮
[WRONG] **错误示例**(使用了圆角和模糊阴影):
```html
<button class="rounded-lg shadow-lg bg-blue-500 text-white px-4 py-2 hover:bg-blue-600">
点击我
</button>
```
[CORRECT] **正确示例**(使用硬边缘、无圆角、位移效果):
```html
<button class="bg-[#3a3a3c] text-white/90 rounded-lg transition-colors duration-200 bg-[#ff006e] text-white px-4 py-2 md:px-6 md:py-3">
点击我
</button>
```
### 卡片
[WRONG] **错误示例**(使用了渐变和圆角):
```html
<div class="rounded-xl shadow-2xl bg-gradient-to-r from-purple-500 to-pink-500 p-6">
<h3 class="text-xl font-semibold">标题</h3>
</div>
```
[CORRECT] **正确示例**(纯色背景、硬边缘阴影):
```html
<div class="bg-[#2c2c2e] border border-white/8 rounded-xl p-4 md:p-6">
<h3 class="font-serif font-semibold text-white/95 text-lg md:text-xl">标题</h3>
</div>
```
### 输入框
[WRONG] **错误示例**(灰色边框、圆角):
```html
<input class="rounded-md border border-gray-300 px-3 py-2 focus:ring-2 focus:ring-blue-500" />
```
[CORRECT] **正确示例**(黑色粗边框、聚焦阴影):
```html
<input class="bg-[#1c1c1e] border border-white/10 rounded-lg text-white/90 placeholder-white/30 focus:outline-none focus:border-white/25 transition-colors duration-200 px-3 py-2 md:px-4 md:py-3" placeholder="请输入..." />
```
---
## [TEMPLATES] 页面骨架模板
使用以下模板生成页面,只需替换 `{PLACEHOLDER}` 部分:
### 导航栏骨架
```html
<nav class="bg-white border-b-2 md:border-b-4 border-black px-4 md:px-8 py-3 md:py-4">
<div class="flex items-center justify-between max-w-6xl mx-auto">
<a href="/" class="font-black text-xl md:text-2xl tracking-wider">
{LOGO_TEXT}
</a>
<div class="flex gap-4 md:gap-8 font-mono text-sm md:text-base">
{NAV_LINKS}
</div>
</div>
</nav>
```
### Hero 区块骨架
```html
<section class="min-h-[60vh] md:min-h-[80vh] flex items-center px-4 md:px-8 py-12 md:py-0 bg-{ACCENT_COLOR} border-b-2 md:border-b-4 border-black">
<div class="max-w-4xl mx-auto">
<h1 class="font-black text-4xl md:text-6xl lg:text-8xl leading-tight tracking-tight mb-4 md:mb-6">
{HEADLINE}
</h1>
<p class="font-mono text-base md:text-xl max-w-xl mb-6 md:mb-8">
{SUBHEADLINE}
</p>
<button class="bg-black text-white font-black px-6 py-3 md:px-8 md:py-4 border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px] transition-all text-sm md:text-base">
{CTA_TEXT}
</button>
</div>
</section>
```
### 卡片网格骨架
```html
<section class="py-12 md:py-24 px-4 md:px-8">
<div class="max-w-6xl mx-auto">
<h2 class="font-black text-2xl md:text-4xl mb-8 md:mb-12">{SECTION_TITLE}</h2>
<div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 md:gap-6">
<!-- Card template - repeat for each card -->
<div class="bg-white border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(0,0,0,1)] md:shadow-[8px_8px_0px_0px_rgba(0,0,0,1)] p-4 md:p-6 hover:shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:hover:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:-translate-y-1 transition-all">
<h3 class="font-black text-lg md:text-xl mb-2">{CARD_TITLE}</h3>
<p class="font-mono text-sm md:text-base text-gray-700">{CARD_DESCRIPTION}</p>
</div>
</div>
</div>
</section>
```
### 页脚骨架
```html
<footer class="bg-black text-white py-12 md:py-16 px-4 md:px-8 border-t-2 md:border-t-4 border-black">
<div class="max-w-6xl mx-auto">
<div class="grid grid-cols-1 md:grid-cols-3 gap-8">
<div>
<span class="font-black text-xl md:text-2xl">{LOGO_TEXT}</span>
<p class="font-mono text-sm mt-4 text-gray-400">{TAGLINE}</p>
</div>
<div>
<h4 class="font-black text-lg mb-4">{COLUMN_TITLE}</h4>
<ul class="space-y-2 font-mono text-sm text-gray-400">
{FOOTER_LINKS}
</ul>
</div>
</div>
</div>
</footer>
```
---
## [CHECKLIST] 生成后自检清单
**在输出代码前,必须逐项验证以下每一条。如有违反,立即修正后再输出:**
### 1. 圆角检查
- [ ] 搜索代码中的 `rounded-`
- [ ] 确认只有 `rounded-none` 或无圆角
- [ ] 如果发现 `rounded-lg`、`rounded-md` 等,替换为 `rounded-none`
### 2. 阴影检查
- [ ] 搜索代码中的 `shadow-`
- [ ] 确认只使用 `shadow-[Xpx_Xpx_0px_0px_rgba(...)]` 格式
- [ ] 如果发现 `shadow-lg`、`shadow-xl` 等,替换为正确格式
### 3. 边框检查
- [ ] 搜索代码中的 `border-`
- [ ] 确认边框颜色是 `border-black`
- [ ] 如果发现 `border-gray-*`、`border-slate-*`,替换为 `border-black`
### 4. 交互检查
- [ ] 所有按钮都有 `hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px]`
- [ ] 所有卡片都有 hover 效果(阴影变色或位移)
- [ ] 都包含 `transition-all`
### 5. 响应式检查
- [ ] 边框有 `border-2 md:border-4`
- [ ] 阴影有 `shadow-[4px...] md:shadow-[8px...]`
- [ ] 间距有 `p-4 md:p-6` 或类似的响应式值
- [ ] 字号有 `text-sm md:text-base` 或类似的响应式值
### 6. 字体检查
- [ ] 标题使用 `font-black`
- [ ] 正文使用 `font-mono`
> CRITICAL: **如果任何一项检查不通过,必须修正后重新生成代码。**
---
## [EXAMPLES] 示例 Prompt
### 1. macOS Settings App
macOS 风格的设置页面
```
Create a macOS Vibrancy settings page with:
1. Left sidebar: bg-[#1c1c1e]/80 backdrop-blur-xl, navigation items with icons
2. Active item: bg-white/10 rounded-lg
3. Main content: bg-[#2c2c2e], settings sections with 1px borders
4. Toggle switches, input fields, dropdown selects
5. All text white/95 for labels, white/60 for descriptions
6. No gradients, no shadows, no animations
```
### 2. Code Editor
macOS 风格的代码编辑器
```
Create a macOS Vibrancy code editor layout with:
1. File tree sidebar: bg-[#1c1c1e]/80 backdrop-blur-xl, tree items with indent
2. Editor area: bg-[#2c2c2e], monospace font, line numbers in white/30
3. Tab bar: bg-[#2c2c2e] border-b border-white/8, active tab slightly lighter
4. Status bar: bg-[#1c1c1e] border-t border-white/8, small text
5. All borders 1px, no shadows, no gradients
```
### 3. Chat Application
macOS 风格的聊天应用
```
Create a macOS Vibrancy chat app with:
1. Conversation list sidebar: bg-[#1c1c1e]/80 backdrop-blur-xl
2. Chat area: bg-[#2c2c2e], messages in bg-[#3a3a3c] rounded-xl
3. Input bar: bg-[#1c1c1e] border-t border-white/8
4. Search bar in sidebar: bg-[#1c1c1e] rounded-lg
5. Timestamps in white/40, names in white/90
6. No gradients, no glow, 1px borders only
```Flexible constraints for quick ideation
STYLEKIT_STYLE_REFERENCE
style_name: macOS 毛玻璃
style_slug: macos-vibrancy
style_source: /styles/macos-vibrancy
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- macOS
- 原生
- 暗色
- 毛玻璃
- 桌面
- vibrancy
## Prefer
- Use three-depth dark gray system: #1c1c1e (deepest) -> #2c2c2e -> #3a3a3c (lightest)
- Sidebar uses backdrop-blur-xl with bg-[#1c1c1e]/80 for vibrancy effect
- All borders are 1px border-white/8 to border-white/12, never thicker
- Headings use serif font (Georgia, serif), body uses system sans-serif
## Avoid
- No gradients on any element (backgrounds are solid dark grays)
- No glow effects, no box-shadow larger than 2px spread
- No decorative animations (pulse, bounce, spin)
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。Component Templates
Restrained dark button with subtle hover state
/* macOS Vibrancy Global Styles */
:root {
--mv-bg-deep: #1c1c1e;
--mv-bg-mid: #2c2c2e;
--mv-bg-surface: #3a3a3c;
--mv-border: rgba(255, 255, 255, 0.08);
--mv-text: rgba(255, 255, 255, 0.95);
--mv-text-secondary: rgba(255, 255, 255, 0.7);
--mv-text-muted: rgba(255, 255, 255, 0.4);
--mv-accent: #0a84ff;
}
.mv-sidebar {
background: rgba(28, 28, 30, 0.8);
backdrop-filter: blur(20px);
-webkit-backdrop-filter: blur(20px);
border-right: 1px solid var(--mv-border);
}
.mv-panel {
background: var(--mv-bg-mid);
border: 1px solid var(--mv-border);
}
@keyframes macos-vibrancy-fade-in {
from { opacity: 0; transform: translateY(8px); }
to { opacity: 1; transform: translateY(0); }
}
@keyframes macos-vibrancy-pulse {
0%, 100% { opacity: 1; }
50% { opacity: 0.7; }
}
.macos-vibrancy-card {
position: relative;
overflow: hidden;
}
.macos-vibrancy-card::before {
content: "";
position: absolute;
inset: 0;
opacity: 0;
transition: opacity 0.3s ease;
background: linear-gradient(135deg, rgba(58, 58, 60, 0.05), transparent);
pointer-events: none;
}
.macos-vibrancy-card:hover::before {
opacity: 1;
}
.macos-vibrancy-gradient {
background: linear-gradient(135deg, #3a3a3c, #0a84ff);
}
.macos-vibrancy-gradient-text {
background: linear-gradient(135deg, #3a3a3c, #0a84ff);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.macos-vibrancy-accent-corner {
clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2rem), calc(100% - 2rem) 100%, 0 100%);
}
.macos-vibrancy-animate-in {
animation: macos-vibrancy-fade-in 0.5s ease-out both;
}IDE Integration
Download config files for your AI coding assistant to generate code following this style.
Style Pack
Get the complete machine-readable style assets including Design Tokens, Tailwind presets, CSS variables, and shadcn/ui themes.
Metadata
Style metadata including version information
Design Tokens
Compatible with Figma / Style Dictionary / Tokens Studio
Tailwind Preset
Tailwind CSS theme preset, import directly in config
Global CSS
CSS variables and base styles
shadcn Theme
shadcn/ui theme configuration
CSS Variables
Pure CSS variables, works with any project
SKILL.md
Loadable skill pack for Cursor / Claude Code / VS Code
macOS Vibrancy is the Web adaptation of Apple's desktop application design language. Its core is restraint, not spectacle.
WCAG 2.1 compliance analysis based on color contrast ratios and typography readability.
Overall Score
Grade: D - Poor
Contrast Ratios
Readability
Score
67/100
Font Size
text-sm
Font Weight
font-serif font-semibold text-white/95
Line Height
default
Scores are based on WCAG 2.1 guidelines. AA requires 4.5:1 contrast for normal text and 3:1 for large text. AAA requires 7:1 for normal text and 4.5:1 for large text.
Further Reading
This section is better for readers who already like the direction and want more depth.