Best For
俏皮野兽派 / 多彩 / 倾斜元素
Neo-Brutalist Playful
A lively version of Neo-Brutalist. Retains core characteristics while adding more colors, rotated/tilted elements, icon decorations, and playful micro-interactions -- ideal for youth-oriented brands.
Best For
俏皮野兽派 / 多彩 / 倾斜元素
Primary Move
Keep no rounded corners rounded-none
Watch Out
Do not use rounded corners
Showcase Entry
Live preview of the showcase page. Click to explore the full experience.
Color Palette
Primary
#000000
Secondary
#ffffff
Accent 1
#ff6b6b
Accent 2
#4ecdc4
Prompts
Use one-click prompts to generate 俏皮野兽派 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: 俏皮野兽派
style_slug: neo-brutalist-playful
style_source: /styles/neo-brutalist-playful
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# Neo-Brutalist Playful (俏皮野兽派) Design System
> Neo-Brutalist 的活泼版本。保留核心特征,加入更多色彩、旋转倾斜元素、图标化装饰和有趣的微交互,适合年轻化品牌。
## 核心理念
Neo-Brutalist Playful(俏皮野兽派)是原版 Neo-Brutalist 的活泼变体。在保持硬边缘、无圆角的结构基础上,通过以下方式增加趣味性:
特色元素:
- 元素轻微旋转 rotate-[-2deg] 或 rotate-[1deg]
- 多彩色块组合
- 适当使用图标作为装饰(Lucide React 等)
- 更活泼的 hover 动画(scale、bounce)
- 手写风格的装饰文字
适用场景:年轻化品牌、创意工作室、儿童产品、趣味应用
设计原则:
- 视觉一致性:所有组件必须遵循统一的视觉语言,从色彩到字体到间距保持谐调
- 层次分明:通过颜色深浅、字号大小、留白空间建立清晰的信息层级
- 交互反馈:每个可交互元素都必须有明确的 hover、active、focus 状态反馈
- 响应式适配:设计必须在移动端、平板、桌面端上保持一致的体验
- 无障碍性:确保色彩对比度符合 WCAG 2.1 AA 标准,所有交互元素可键盘访问
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border-4
颜色: border-black
圆角: rounded-none
```
### 阴影
```
小: shadow-[4px_4px_0px_0px_rgba(0,0,0,1)]
中: shadow-[6px_6px_0px_0px_rgba(0,0,0,1)]
大: shadow-[8px_8px_0px_0px_rgba(0,0,0,1)]
悬停: hover:shadow-none
聚焦: focus:shadow-[6px_6px_0px_0px_rgba(78,205,196,1)]
```
### 交互效果
```
悬停位移: hover:translate-x-[3px] hover:translate-y-[3px]
过渡动画: transition-all duration-300
按下状态: active:translate-x-[4px] active:translate-y-[4px]
```
### 字体
```
标题: font-black uppercase
正文: font-mono
```
### 字号
```
Hero: text-5xl md:text-7xl lg:text-9xl
H1: text-4xl md:text-6xl
H2: text-2xl md:text-4xl
H3: text-xl md:text-2xl
正文: text-sm md:text-base
小字: text-xs md:text-sm
```
### 间距
```
Section: py-12 md:py-20 lg:py-28
容器: px-4 md:px-8 lg:px-12
卡片: p-4 md:p-6
```
---
## [FORBIDDEN] 绝对禁止
以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:
### 禁止的 Class
- `rounded-lg`
- `rounded-xl`
- `rounded-2xl`
- `rounded-full`
- `shadow-sm`
- `shadow`
- `shadow-md`
- `shadow-lg`
- `bg-gradient-to-r`
- `bg-gradient-to-b`
- `text-gray-300`
- `text-gray-400`
- `text-gray-500`
- `bg-gray-50`
- `bg-gray-100`
- `font-light`
- `font-normal`
- `backdrop-blur`
### 禁止的模式
- 匹配 `^rounded-(?:sm|md|lg|xl|2xl|3xl|full)$`
- 匹配 `^shadow-(?:sm|md|lg|xl|2xl)$`
- 匹配 `^bg-gradient-`
- 匹配 `^font-(?:light|thin|normal)$`
- 匹配 `^backdrop-blur`
### 禁止原因
- `rounded-lg`: Neo-Brutalist Playful uses sharp corners only (rounded-none)
- `shadow-md`: Neo-Brutalist Playful uses hard-edge offset shadows, not blurred
- `bg-gradient-to-r`: Neo-Brutalist Playful uses solid color blocks, no gradients
- `font-light`: Neo-Brutalist Playful uses bold/black font weights for impact
- `bg-gray-100`: Neo-Brutalist Playful uses vibrant colors, not subtle grays
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
rounded-none
border-4 border-black
shadow-[6px_6px_0px_0px_rgba(0,0,0,1)]
hover:shadow-none
hover:translate-x-[3px] hover:translate-y-[3px]
transition-all
font-black
```
### 卡片必须包含
```
rounded-none
border-4 border-black
bg-white
```
### 输入框必须包含
```
rounded-none
border-4 border-black
font-mono
focus:outline-none
focus:shadow-[6px_6px_0px_0px_rgba(78,205,196,1)]
transition-all
```
---
## [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="rounded-none border-4 border-black shadow-[6px_6px_0px_0px_rgba(0,0,0,1)] hover:shadow-none hover:translate-x-[3px] hover:translate-y-[3px] transition-all font-black 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="rounded-none border-4 border-black bg-white p-4 md:p-6">
<h3 class="font-black uppercase text-xl md:text-2xl">标题</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="rounded-none border-4 border-black font-mono focus:outline-none focus:shadow-[6px_6px_0px_0px_rgba(78,205,196,1)] transition-all 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. 儿童教育网站
活泼有趣的学习平台
```
用 Neo-Brutalist Playful 风格创建一个儿童教育网站,要求:
1. 导航:彩色按钮,每个用不同鲜艳色
2. Hero:大标题带颜色高亮,可爱插图
3. 课程卡片:彩色边框和阴影,hover 放大 + 上浮
4. 进度条:彩色条纹或波浪效果
5. 按钮:圆形装饰点缀,hover 时旋转
配色:明黄、粉红、天蓝、青绿交替使用
```
### 2. 活动报名页
有趣的活动宣传和报名
```
用 Neo-Brutalist Playful 风格设计一个活动报名页,要求:
1. Hero:大胆标题,彩色文字或高亮背景
2. 活动信息:卡片式布局,每个信息点用不同色块
3. 时间线:彩色圆点连接,每阶段不同色
4. 报名表单:彩色边框输入框,提交按钮醒目
5. 装饰:几何图形点缀(方块、圆点)
整体活泼但保持野兽派的硬边缘和粗边框
```
### 3. 创意作品集
个性化的作品展示
```
用 Neo-Brutalist Playful 风格创建一个创意作品集,要求:
1. 首页:大胆的自我介绍,彩色文字
2. 作品网格:每个项目卡片用不同彩色阴影
3. 项目详情:全屏图片,彩色边框
4. 技能展示:彩色进度条或图标
5. 联系区:趣味表单,彩色按钮
保持无圆角、粗边框、硬阴影的野兽派特征
```Flexible constraints for quick ideation
STYLEKIT_STYLE_REFERENCE
style_name: 俏皮野兽派
style_slug: neo-brutalist-playful
style_source: /styles/neo-brutalist-playful
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- 俏皮野兽派
- 多彩
- 倾斜元素
- 图标
- 年轻化
- expressive
## Prefer
- 保持无圆角 rounded-none
- 使用纯黑边框 border-4 border-black
- 元素添加轻微旋转 rotate-[-2deg] rotate-[1deg]
- 使用多种强调色,色彩丰富
## Avoid
- 禁止圆角
- 禁止模糊阴影
- 禁止渐变
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。Component Templates
俏皮版 Brutal 按钮
/* Neo-Brutalist Playful 全局样式 */
:root {
--playful-red: #ff6b6b;
--playful-teal: #4ecdc4;
--playful-yellow: #ffe66d;
--playful-mint: #95e1d3;
--playful-coral: #f38181;
}
body {
background: white;
color: black;
}
/* 标题 - 极粗 */
h1, h2, h3, h4, h5, h6 {
font-weight: 900;
}
/* 选中文字 - 俏皮红 */
::selection {
background: var(--playful-red);
color: white;
}
/* 有趣的下划线 */
.fun-underline {
text-decoration: underline;
text-decoration-color: var(--playful-yellow);
text-decoration-thickness: 4px;
text-underline-offset: 4px;
}
@keyframes neo-brutalist-playful-fade-in {
from { opacity: 0; transform: translateY(8px); }
to { opacity: 1; transform: translateY(0); }
}
@keyframes neo-brutalist-playful-pulse {
0%, 100% { opacity: 1; }
50% { opacity: 0.7; }
}
.neo-brutalist-playful-card {
position: relative;
overflow: hidden;
}
.neo-brutalist-playful-card::before {
content: "";
position: absolute;
inset: 0;
opacity: 0;
transition: opacity 0.3s ease;
background: linear-gradient(135deg, rgba(0, 0, 0, 0.05), transparent);
pointer-events: none;
}
.neo-brutalist-playful-card:hover::before {
opacity: 1;
}
.neo-brutalist-playful-gradient {
background: linear-gradient(135deg, #000000, #ff6b6b);
}
.neo-brutalist-playful-gradient-text {
background: linear-gradient(135deg, #000000, #ff6b6b);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
}
.neo-brutalist-playful-frosted {
backdrop-filter: blur(12px) saturate(180%);
-webkit-backdrop-filter: blur(12px) saturate(180%);
background: rgba(0, 0, 0, 0.08);
}
.neo-brutalist-playful-accent-corner {
clip-path: polygon(0 0, 100% 0, 100% calc(100% - 2rem), calc(100% - 2rem) 100%, 0 100%);
}
.neo-brutalist-playful-animate-in {
animation: neo-brutalist-playful-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
Neo-Brutalist Playful is a lively variant of the original Neo-Brutalist. While maintaining the hard-edge, no-rounded-corner structural foundation, it adds fun through:
WCAG 2.1 compliance analysis based on color contrast ratios and typography readability.
Overall Score
Grade: C - Fair
Contrast Ratios
| Context | Colors | Ratio | AA | AAA |
|---|---|---|---|---|
| Text on background | /#000000 / #ffffff | 21:1 | ||
| Secondary text on background | /#ffffff / #ffffff | 1:1 | ||
| Muted text on background | /#374151 / #ffffff | 10.31:1 | ||
| Text on secondary background | /#000000 / #000000 | 1:1 | ||
| Secondary text on secondary | /#ffffff / #000000 | 21:1 | ||
| Button primary | /#ffffff / #ff6b6b | 2.78:1 | ||
| Text on accent 1 | /#000000 / #ff6b6b | 7.57:1 | ||
| Alt text on accent 1 | /#ffffff / #ff6b6b | 2.78:1 | ||
| Text on accent 2 | /#000000 / #4ecdc4 | 10.85:1 | ||
| Alt text on accent 2 | /#ffffff / #4ecdc4 | 1.93:1 | ||
| Text on accent 3 | /#000000 / #ffe66d | 16.79:1 | ||
| Alt text on accent 3 | /#ffffff / #ffe66d | 1.25:1 | ||
| Text on accent 4 | /#000000 / #95e1d3 | 13.99:1 | ||
| Alt text on accent 4 | /#ffffff / #95e1d3 | 1.5:1 | ||
| Text on accent 5 | /#000000 / #f38181 | 8.27:1 | ||
| Alt text on accent 5 | /#ffffff / #f38181 | 2.54:1 |
Readability
Score
82/100
Font Size
text-sm md:text-base
Font Weight
font-black uppercase
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.