Cyber-Noir Manga Dossier
A portable design language for agents: download the markdown first, then inspect the preview, tokens, and rules as needed.
Download DESIGN.md
Portable DESIGN.md source of truth for most agents and apps.
specification
philosophy
tokens
borders4 items
- accent width
- 3px
- character
- Mostly near-invisible white or black hairlines, interrupted by thick magenta danger bars and rectangular scan frames.
- default width
- 1px
- style
- solid
colors12 items
motion3 items
- duration
- 180ms
- easing
- cubic-bezier(.2,.8,.1,1)
- philosophy
- Minimal mechanical confirmation: labels blink once, scan frames drift by 2px, and hover states invert like a printed negative.
radii5 items
- full
- 9999px
- lg
- 24px
- md
- 16px
- none
- 0
- sm
- 0
shadows3 items
- lg
- 0 40px 120px rgba(0,0,0,.72)
- md
- 0 18px 60px rgba(0,0,0,.46)
- sm
- 0 1px 0 rgba(255,255,255,.08)
spacing2 items
- base
- 8px
- scale
- 4, 8, 12, 16, 24, 32, 48, 64, 96, 128
surfaces3 items
- bg pattern
- Subtle scanlines, radial halftone dots, crop marks, and checksum text embedded into large negative-space fields.
- card style
- Square-corner dossiers with 1px translucent borders, clipped manga crops, magenta status tabs, and no generic card shadow stacks.
- treatment
- Matte ink black and bone editorial paper; glass appears only as narrow Y2K micro-panels with rgba white veils and hairline highlights.
typography8 items
- base size
- 16px
- body font
- Saira Condensed
- google fonts url
- https://fonts.googleapis.com/css2?family=Bodoni+Moda:opsz,wght@6..96,600;6..96,800&family=Fragment+Mono:ital@0;1&family=Saira+Condensed:wght@300;400;500;600;700&display=swap
- heading font
- Bodoni Moda
- letter spacing
- -0.02em
- line height
- 1.55
- mono font
- Fragment Mono
- scale ratio
- 1.28
rules
Compose screens like a luxury dossier made from surveillance manga crops: one dominant full-bleed panel, one dense terminal column, and several small evidence strips. Avoid centered symmetry except for title-card impact. Let panels collide with gutters and viewport edges while keeping the reading path precise.
Alternate severe emptiness with compressed diagnostic clusters so the page feels cinematic and nocturnal rather than uniformly busy.
Hierarchy moves from oversized condensed or Bodoni title cards to small uppercase dossier IDs, then to terminal mono diagnostics. Magenta never fills large areas; it marks danger, status, or selection. White space is a primary hierarchy device, not an empty area to decorate.
layout
>=1200px cinematic dossier spread; 768-1199px two-column tablet stack with preserved edge crops; <768px single-column vertical title sequence with horizontal diagnostic strips.
High contrast between open editorial fields and compact diagnostic clusters; dense zones should occupy less area but carry more microtext.
Desktop uses a 12-column asymmetric grid with 24px gutters and max width around 1480px; key panels span 5, 7, or 9 columns to prevent equal-card rhythm.
Use 64-128px voids around title cards and 4-12px gaps inside diagnostic clusters, maintaining at least an 8:1 spacing rhythm.
guidance
- Use black, bone white, and one surgical magenta accent as the visible palette; keep green or cyan to tiny terminal microtext only.
- Crop manga-like panels aggressively and overlay them with scan rectangles, crop marks, and exposure ticks.
- Write interface copy as terse dossier evidence: checksum, exposure, port, ghost, frame, null, and warning language.
- Give one composition a dominant panel and another a dense diagnostic strip; never make equal cards the main structure.
- Use body tracking at -0.02em and display tracking between -0.03em and -0.04em for polished editorial tension.
- Preserve square corners and hairline borders unless a small glass port requires the 16px radius token.
- Do not use rainbow neon cyberpunk, large cyan glows, or colorful anime poster palettes.
- Do not create generic dashboard charts, CRM widgets, or three identical cards in a row.
- Do not add cute manga stickers, emoji, playful mascots, or childish speech bubbles.
- Do not let glassmorphism become the surface language; chrome is only a micro-accent.
- Do not rely on stock photography or literal anime screenshots; construct the mood with CSS panels and typography.
- Do not soften the system with arbitrary rounded corners, drop-shadow stacks, or friendly app gradients.
katagami spec
# Cyber-Noir Manga Dossier ## Philosophy A polished cyber-noir editorial system for adult near-future interfaces: black-and-white manga pressure, luxury magazine pacing, and terminal diagnostics reduced to surgical magenta interruptions. It treats software as a confidential fashion dossier for an absent body, where scan frames and checksum strings become the ornament. ### Values - High-fashion restraint: one chromatic accent, large negative space, and typography doing more work than decoration. - Manga tension through cropped monochrome panels, hard gutters, ink silhouettes, and tonal speed-line pressure rather than illustrative clutter. - Diagnostic intimacy: terminal snippets, exposure meters, bounding boxes, and port diagrams act as evidence labels around the content. - Adult anime coolness: nocturnal, existential, composed, and alienated; never cute, toy-like, or rainbow cyberpunk. - Asymmetry as narrative editing: pages should feel spliced from surveillance footage, title cards, and magazine spreads. ### Anti-Values - Generic neon cyberpunk gradients, rainbow glows, and busy gamer HUD decoration. - Equal-card SaaS dashboards, friendly rounded app chrome, and anonymous analytics screens. - Playful manga stickers, kawaii expressions, and comic-book color fills that weaken the noir mood. - Over-polished glassmorphism that hides the black-and-white editorial structure. ### Visual Character - Use full-bleed black and bone-white editorial slabs with sharply offset CSS grid columns and gutters that crop panels at the viewport edge. - Build manga image zones as monochrome CSS panels using hard borders, halftone radial patterns, diagonal ink cuts, and absolute scan-frame rectangles. - Place narrow magenta warning tags and OCR-style terminal strings as small absolute-positioned labels crossing gutters, corners, and panel seams. - Pair oversized condensed editorial display type with compressed sans body captions and a distinct mono diagnostic layer, all tightly tracked. - Keep Y2K chrome to tiny inset glass strips and port diagrams only, using hairline borders and low-opacity reflections instead of broad gradients. ## Tokens ### Borders - **Accent Width**: 3px - **Character**: Mostly near-invisible white or black hairlines, interrupted by thick magenta danger bars and rectangular scan frames. - **Default Width**: 1px - **Style**: solid ### Colors | Name | Value | |------|-------| | accent | `#C2185B` | | background | `#050506` | | border | `#FFFFFF14` | | error | `#C2185B` | | info | `#5F8C8E` | | muted | `#8E8A83` | | primary | `#09090A` | | secondary | `#F3F0EA` | | success | `#6F8F72` | | surface | `#F6F2EA` | | text | `#F8F5EF` | | warning | `#B86A42` | ### Motion - **Duration**: 180ms - **Easing**: cubic-bezier(.2,.8,.1,1) - **Philosophy**: Minimal mechanical confirmation: labels blink once, scan frames drift by 2px, and hover states invert like a printed negative. ### Radii - **Full**: 9999px - **Lg**: 24px - **Md**: 16px - **None**: 0 - **Sm**: 0 ### Shadows - **Lg**: 0 40px 120px rgba(0,0,0,.72) - **Md**: 0 18px 60px rgba(0,0,0,.46) - **Sm**: 0 1px 0 rgba(255,255,255,.08) ### Spacing - **Base**: 8px - **Scale**: [4,8,12,16,24,32,48,64,96,128] ### Surfaces - **Bg Pattern**: Subtle scanlines, radial halftone dots, crop marks, and checksum text embedded into large negative-space fields. - **Card Style**: Square-corner dossiers with 1px translucent borders, clipped manga crops, magenta status tabs, and no generic card shadow stacks. - **Treatment**: Matte ink black and bone editorial paper; glass appears only as narrow Y2K micro-panels with rgba white veils and hairline highlights. ### Typography - **Base Size**: 16px - **Body Font**: Saira Condensed - **Google Fonts Url**: https://fonts.googleapis.com/css2?family=Bodoni+Moda:opsz,wght@6..96,600;6..96,800&family=Fragment+Mono:ital@0;1&family=Saira+Condensed:wght@300;400;500;600;700&display=swap - **Heading Font**: Bodoni Moda - **Letter Spacing**: -0.02em - **Line Height**: 1.55 - **Mono Font**: Fragment Mono - **Scale Ratio**: 1.28 ## Rules ### Composition Compose screens like a luxury dossier made from surveillance manga crops: one dominant full-bleed panel, one dense terminal column, and several small evidence strips. Avoid centered symmetry except for title-card impact. Let panels collide with gutters and viewport edges while keeping the reading path precise. ### Density Alternate severe emptiness with compressed diagnostic clusters so the page feels cinematic and nocturnal rather than uniformly busy. ### Hierarchy Hierarchy moves from oversized condensed or Bodoni title cards to small uppercase dossier IDs, then to terminal mono diagnostics. Magenta never fills large areas; it marks danger, status, or selection. White space is a primary hierarchy device, not an empty area to decorate. ### Signature Patterns - Manga scan panels use CSS pseudo-elements for crop marks, halftone dot fields, diagonal black cuts, and floating bounding boxes over monochrome content. - Magenta checksum tags are positioned as thin vertical or horizontal strips that pierce panel seams and label states with terse error language. - Terminal ornament is clipped into gutters: mono strings, port labels, and exposure ticks run along edges instead of appearing as standalone widgets. - Y2K chrome is restricted to small inset micro-panels with translucent glass, inner hairlines, and tiny cyan-green terminal text accents. ## Layout ### Breakpoints >=1200px cinematic dossier spread; 768-1199px two-column tablet stack with preserved edge crops; <768px single-column vertical title sequence with horizontal diagnostic strips. ### Density High contrast between open editorial fields and compact diagnostic clusters; dense zones should occupy less area but carry more microtext. ### Grid Desktop uses a 12-column asymmetric grid with 24px gutters and max width around 1480px; key panels span 5, 7, or 9 columns to prevent equal-card rhythm. ### Whitespace Use 64-128px voids around title cards and 4-12px gaps inside diagnostic clusters, maintaining at least an 8:1 spacing rhythm. ## Guidance ### Do - Use black, bone white, and one surgical magenta accent as the visible palette; keep green or cyan to tiny terminal microtext only. - Crop manga-like panels aggressively and overlay them with scan rectangles, crop marks, and exposure ticks. - Write interface copy as terse dossier evidence: checksum, exposure, port, ghost, frame, null, and warning language. - Give one composition a dominant panel and another a dense diagnostic strip; never make equal cards the main structure. - Use body tracking at -0.02em and display tracking between -0.03em and -0.04em for polished editorial tension. - Preserve square corners and hairline borders unless a small glass port requires the 16px radius token. ### Don't - Do not use rainbow neon cyberpunk, large cyan glows, or colorful anime poster palettes. - Do not create generic dashboard charts, CRM widgets, or three identical cards in a row. - Do not add cute manga stickers, emoji, playful mascots, or childish speech bubbles. - Do not let glassmorphism become the surface language; chrome is only a micro-accent. - Do not rely on stock photography or literal anime screenshots; construct the mood with CSS panels and typography. - Do not soften the system with arbitrary rounded corners, drop-shadow stacks, or friendly app gradients. ### Accessibility Maintain strong black-white contrast for body copy, pair magenta state with text and border changes, keep touch targets above 44px, and offer reduced motion for scan or blink effects. ### Usage Context Best for cinematic product launches, confidential AI companion interfaces, luxury wearable diagnostics, music/anime title experiences, and editorial portfolios that need adult cyber-noir restraint.
DESIGN.md
---
version: "alpha"
name: "Cyber-Noir Manga Dossier"
description: "Agent-curated design language exported from Katagami as DESIGN.md."
colors:
accent: "#C2185B"
background: "#050506"
error: "#C2185B"
info: "#5F8C8E"
muted: "#8E8A83"
primary: "#09090A"
secondary: "#F3F0EA"
success: "#6F8F72"
surface: "#F6F2EA"
text: "#F8F5EF"
warning: "#B86A42"
typography:
headline-lg:
fontFamily: "Bodoni Moda"
fontSize: "2.097rem"
fontWeight: 700
lineHeight: 1.1
letterSpacing: "-0.02em"
headline-md:
fontFamily: "Bodoni Moda"
fontSize: "1.638rem"
fontWeight: 600
lineHeight: 1.15
letterSpacing: "-0.02em"
body-md:
fontFamily: "Saira Condensed"
fontSize: "16px"
fontWeight: 400
lineHeight: 1.55
letterSpacing: "-0.02em"
label-md:
fontFamily: "Fragment Mono"
fontSize: "0.75rem"
fontWeight: 600
lineHeight: 1
letterSpacing: "0.08em"
rounded:
full: "9999px"
lg: "24px"
md: "16px"
none: "0px"
sm: "0px"
spacing:
base: "8px"
xs: "4px"
sm: "8px"
md: "12px"
lg: "16px"
xl: "24px"
2xl: "32px"
3xl: "48px"
4xl: "64px"
step-8: "96px"
step-9: "128px"
components:
color-reference-accent:
backgroundColor: "{colors.accent}"
color-reference-background:
backgroundColor: "{colors.background}"
color-reference-error:
backgroundColor: "{colors.error}"
color-reference-info:
backgroundColor: "{colors.info}"
color-reference-muted:
backgroundColor: "{colors.muted}"
color-reference-primary:
backgroundColor: "{colors.primary}"
color-reference-secondary:
backgroundColor: "{colors.secondary}"
color-reference-success:
backgroundColor: "{colors.success}"
color-reference-surface:
backgroundColor: "{colors.surface}"
color-reference-text:
backgroundColor: "{colors.text}"
color-reference-warning:
backgroundColor: "{colors.warning}"
button-primary:
backgroundColor: "{colors.primary}"
textColor: "#ffffff"
typography: "{typography.label-md}"
rounded: "{rounded.md}"
padding: "{spacing.md}"
card-surface:
backgroundColor: "{colors.surface}"
textColor: "{colors.text}"
rounded: "{rounded.md}"
padding: "{spacing.md}"
input-default:
backgroundColor: "{colors.surface}"
textColor: "{colors.text}"
rounded: "{rounded.md}"
height: "44px"
---
# Cyber-Noir Manga Dossier
## Overview
A polished cyber-noir editorial system for adult near-future interfaces: black-and-white manga pressure, luxury magazine pacing, and terminal diagnostics reduced to surgical magenta interruptions. It treats software as a confidential fashion dossier for an absent body, where scan frames and checksum strings become the ornament.
### Values
- High-fashion restraint: one chromatic accent, large negative space, and typography doing more work than decoration.
- Manga tension through cropped monochrome panels, hard gutters, ink silhouettes, and tonal speed-line pressure rather than illustrative clutter.
- Diagnostic intimacy: terminal snippets, exposure meters, bounding boxes, and port diagrams act as evidence labels around the content.
- Adult anime coolness: nocturnal, existential, composed, and alienated; never cute, toy-like, or rainbow cyberpunk.
- Asymmetry as narrative editing: pages should feel spliced from surveillance footage, title cards, and magazine spreads.
### Anti-Values
- Generic neon cyberpunk gradients, rainbow glows, and busy gamer HUD decoration.
- Equal-card SaaS dashboards, friendly rounded app chrome, and anonymous analytics screens.
- Playful manga stickers, kawaii expressions, and comic-book color fills that weaken the noir mood.
- Over-polished glassmorphism that hides the black-and-white editorial structure.
### Visual Character
- Use full-bleed black and bone-white editorial slabs with sharply offset CSS grid columns and gutters that crop panels at the viewport edge.
- Build manga image zones as monochrome CSS panels using hard borders, halftone radial patterns, diagonal ink cuts, and absolute scan-frame rectangles.
- Place narrow magenta warning tags and OCR-style terminal strings as small absolute-positioned labels crossing gutters, corners, and panel seams.
- Pair oversized condensed editorial display type with compressed sans body captions and a distinct mono diagnostic layer, all tightly tracked.
- Keep Y2K chrome to tiny inset glass strips and port diagrams only, using hairline borders and low-opacity reflections instead of broad gradients.
## Colors
Use the YAML color tokens as the normative palette. The prose below names the roles agents should preserve when generating UI.
| Token | Value |
|-------|-------|
| accent | `#C2185B` |
| background | `#050506` |
| error | `#C2185B` |
| info | `#5F8C8E` |
| muted | `#8E8A83` |
| primary | `#09090A` |
| secondary | `#F3F0EA` |
| success | `#6F8F72` |
| surface | `#F6F2EA` |
| text | `#F8F5EF` |
| warning | `#B86A42` |
## Typography
- **Headline-Lg**: Bodoni Moda, 2.097rem, weight 700, line-height 1.1.
- **Headline-Md**: Bodoni Moda, 1.638rem, weight 600, line-height 1.15.
- **Body-Md**: Saira Condensed, 16px, weight 400, line-height 1.55.
- **Label-Md**: Fragment Mono, 0.75rem, weight 600, line-height 1.
## Layout
### Spacing Tokens
- **Base**: `8px`
- **Xs**: `4px`
- **Sm**: `8px`
- **Md**: `12px`
- **Lg**: `16px`
- **Xl**: `24px`
- **2xl**: `32px`
- **3xl**: `48px`
- **4xl**: `64px`
- **Step-8**: `96px`
- **Step-9**: `128px`
### Breakpoints
>=1200px cinematic dossier spread; 768-1199px two-column tablet stack with preserved edge crops; <768px single-column vertical title sequence with horizontal diagnostic strips.
### Density
High contrast between open editorial fields and compact diagnostic clusters; dense zones should occupy less area but carry more microtext.
### Grid
Desktop uses a 12-column asymmetric grid with 24px gutters and max width around 1480px; key panels span 5, 7, or 9 columns to prevent equal-card rhythm.
### Whitespace
Use 64-128px voids around title cards and 4-12px gaps inside diagnostic clusters, maintaining at least an 8:1 spacing rhythm.
## Elevation & Depth
### Shadows
- **Lg**: 0 40px 120px rgba(0,0,0,.72)
- **Md**: 0 18px 60px rgba(0,0,0,.46)
- **Sm**: 0 1px 0 rgba(255,255,255,.08)
## Shapes
### Rounded
- **Full**: `9999px`
- **Lg**: `24px`
- **Md**: `16px`
- **None**: `0px`
- **Sm**: `0px`
### Surfaces
- **Bg Pattern**: Subtle scanlines, radial halftone dots, crop marks, and checksum text embedded into large negative-space fields.
- **Card Style**: Square-corner dossiers with 1px translucent borders, clipped manga crops, magenta status tabs, and no generic card shadow stacks.
- **Treatment**: Matte ink black and bone editorial paper; glass appears only as narrow Y2K micro-panels with rgba white veils and hairline highlights.
### Borders
- **Accent Width**: 3px
- **Character**: Mostly near-invisible white or black hairlines, interrupted by thick magenta danger bars and rectangular scan frames.
- **Default Width**: 1px
- **Style**: solid
## Components
### Composition
Compose screens like a luxury dossier made from surveillance manga crops: one dominant full-bleed panel, one dense terminal column, and several small evidence strips. Avoid centered symmetry except for title-card impact. Let panels collide with gutters and viewport edges while keeping the reading path precise.
### Density
Alternate severe emptiness with compressed diagnostic clusters so the page feels cinematic and nocturnal rather than uniformly busy.
### Hierarchy
Hierarchy moves from oversized condensed or Bodoni title cards to small uppercase dossier IDs, then to terminal mono diagnostics. Magenta never fills large areas; it marks danger, status, or selection. White space is a primary hierarchy device, not an empty area to decorate.
### Signature Patterns
- Manga scan panels use CSS pseudo-elements for crop marks, halftone dot fields, diagonal black cuts, and floating bounding boxes over monochrome content.
- Magenta checksum tags are positioned as thin vertical or horizontal strips that pierce panel seams and label states with terse error language.
- Terminal ornament is clipped into gutters: mono strings, port labels, and exposure ticks run along edges instead of appearing as standalone widgets.
- Y2K chrome is restricted to small inset micro-panels with translucent glass, inner hairlines, and tiny cyan-green terminal text accents.
## shadcn/ui Usage
When the target app uses shadcn/ui, copy DESIGN.md with shadcn instead of the plain DESIGN.md. It contains the same Katagami design-language source plus the shadcn/ui primitives, imports, theme variables, component recipes, and preview-shot guidance.
DESIGN.md with shadcn: `/language/cyber-noir-manga-dossier/DESIGN.with-shadcn.md`.
The shadcn page also exposes optional machine-readable files for automation, but the human-facing handoff is DESIGN.md with shadcn.
Install recommended primitives with `npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table`.
Use these primitives in shadcn apps:
- button
- card
- input
- textarea
- select
- dialog
- sheet
- tabs
- badge
- separator
- checkbox
- switch
- slider
- tooltip
- dropdown-menu
- table
Implementation rule for agents: import shadcn primitives from `@/components/ui/*`, apply the generated CSS variables first, then compose the language-specific recipes from the companion MD. Katagami remains the source of truth; shadcn names are the implementation surface.
## Do's and Don'ts
- Do Use black, bone white, and one surgical magenta accent as the visible palette; keep green or cyan to tiny terminal microtext only.
- Do Crop manga-like panels aggressively and overlay them with scan rectangles, crop marks, and exposure ticks.
- Do Write interface copy as terse dossier evidence: checksum, exposure, port, ghost, frame, null, and warning language.
- Do Give one composition a dominant panel and another a dense diagnostic strip; never make equal cards the main structure.
- Do Use body tracking at -0.02em and display tracking between -0.03em and -0.04em for polished editorial tension.
- Do Preserve square corners and hairline borders unless a small glass port requires the 16px radius token.
- Don't Do not use rainbow neon cyberpunk, large cyan glows, or colorful anime poster palettes.
- Don't Do not create generic dashboard charts, CRM widgets, or three identical cards in a row.
- Don't Do not add cute manga stickers, emoji, playful mascots, or childish speech bubbles.
- Don't Do not let glassmorphism become the surface language; chrome is only a micro-accent.
- Don't Do not rely on stock photography or literal anime screenshots; construct the mood with CSS panels and typography.
- Don't Do not soften the system with arbitrary rounded corners, drop-shadow stacks, or friendly app gradients.
### Accessibility
Maintain strong black-white contrast for body copy, pair magenta state with text and border changes, keep touch targets above 44px, and offer reduced motion for scan or blink effects.
### Usage Context
Best for cinematic product launches, confidential AI companion interfaces, luxury wearable diagnostics, music/anime title experiences, and editorial portfolios that need adult cyber-noir restraint.
shadcn/ui theme
```json
{
"$schema": "https://ui.shadcn.com/schema/registry-item.json",
"name": "cyber-noir-manga-dossier",
"type": "registry:theme",
"title": "Cyber-Noir Manga Dossier shadcn Theme",
"cssVars": {
"theme": {},
"light": {
"background": "#050506",
"foreground": "#F8F5EF",
"card": "#F6F2EA",
"card-foreground": "#F8F5EF",
"popover": "#F6F2EA",
"popover-foreground": "#F8F5EF",
"primary": "#09090A",
"primary-foreground": "#ffffff",
"secondary": "#F3F0EA",
"secondary-foreground": "#111111",
"muted": "#8E8A83",
"muted-foreground": "#F8F5EF",
"accent": "#C2185B",
"accent-foreground": "#ffffff",
"destructive": "#C2185B",
"border": "#FFFFFF14",
"input": "#FFFFFF14",
"ring": "#C2185B",
"chart-1": "#09090A",
"chart-2": "#F3F0EA",
"chart-3": "#C2185B",
"chart-4": "#6F8F72",
"chart-5": "#B86A42",
"sidebar": "#F6F2EA",
"sidebar-foreground": "#F8F5EF",
"sidebar-primary": "#09090A",
"sidebar-primary-foreground": "#ffffff",
"sidebar-accent": "#5F8C8E",
"sidebar-accent-foreground": "#ffffff",
"sidebar-border": "#FFFFFF14",
"sidebar-ring": "#C2185B",
"radius": "16px"
},
"dark": {
"background": "#0f1115",
"foreground": "#f8fafc",
"card": "#181b22",
"card-foreground": "#f8fafc",
"popover": "#181b22",
"popover-foreground": "#f8fafc",
"primary": "#09090A",
"primary-foreground": "#ffffff",
"secondary": "#252a33",
"secondary-foreground": "#f8fafc",
"muted": "#252a33",
"muted-foreground": "#a1a1aa",
"accent": "#C2185B",
"accent-foreground": "#ffffff",
"destructive": "#C2185B",
"border": "#303642",
"input": "#303642",
"ring": "#C2185B",
"chart-1": "#09090A",
"chart-2": "#F3F0EA",
"chart-3": "#C2185B",
"chart-4": "#6F8F72",
"chart-5": "#B86A42",
"sidebar": "#181b22",
"sidebar-foreground": "#f8fafc",
"sidebar-primary": "#09090A",
"sidebar-primary-foreground": "#ffffff",
"sidebar-accent": "#C2185B",
"sidebar-accent-foreground": "#ffffff",
"sidebar-border": "#303642",
"sidebar-ring": "#C2185B",
"radius": "16px"
}
},
"meta": {
"source": "katagami",
"languageId": "cyber-noir-manga-dossier",
"slug": "cyber-noir-manga-dossier",
"componentManifest": [
"button",
"card",
"input",
"textarea",
"select",
"dialog",
"sheet",
"tabs",
"badge",
"separator",
"checkbox",
"switch",
"slider",
"tooltip",
"dropdown-menu",
"table"
],
"installCommand": "npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table",
"nativeTokenNames": {
"borders": [
"accent_width",
"character",
"default_width",
"style"
],
"colors": [
"accent",
"background",
"border",
"error",
"info",
"muted",
"primary",
"secondary",
"success",
"surface",
"text",
"warning"
],
"motion": [
"duration",
"easing",
"philosophy"
],
"radii": [
"full",
"lg",
"md",
"none",
"sm"
],
"shadows": [
"lg",
"md",
"sm"
],
"spacing": [
"base",
"scale"
],
"surfaces": [
"bg_pattern",
"card_style",
"treatment"
],
"typography": [
"base_size",
"body_font",
"google_fonts_url",
"heading_font",
"letter_spacing",
"line_height",
"mono_font",
"scale_ratio"
]
}
}
}
```embodiments
at a glance
Typography
The quick brown fox jumps
The quick brown fox jumps
The quick brown fox jumps
The quick brown fox jumps
Components
Components rendered with this language’s tokens — colors, type, and rounded corners as specified.
Spacing
- base8px
- xs4px
- sm8px
- md12px
- lg16px
- xl24px
- 2xl32px
- 3xl48px
- 4xl64px
- step-896px
- step-9128px
Shape
implementation kit
DESIGN.md with shadcn
Copy this when the target app uses shadcn/ui. It packages the Katagami DESIGN.md context with the install list, theme variables, component recipes, preview-shot contract, and starter TSX in one Markdown companion.
advanced implementation filesoptional machine-readable theme, CSS, TSX starter, recipes, and preview contract
npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table:root {
--background: #050506;
--foreground: #F8F5EF;
--card: #F6F2EA;
--card-foreground: #F8F5EF;
--popover: #F6F2EA;
--popover-foreground: #F8F5EF;
--primary: #09090A;
--primary-foreground: #ffffff;
--secondary: #F3F0EA;
--secondary-foreground: #111111;
--muted: #8E8A83;
--muted-foreground: #F8F5EF;
--accent: #C2185B;
--accent-foreground: #ffffff;
--destructive: #C2185B;
--border: #FFFFFF14;
--input: #FFFFFF14;
--ring: #C2185B;
--chart-1: #09090A;
--chart-2: #F3F0EA;
--chart-3: #C2185B;
--chart-4: #6F8F72;
--chart-5: #B86A42;
--sidebar: #F6F2EA;
--sidebar-foreground: #F8F5EF;
--sidebar-primary: #09090A;
--sidebar-primary-foreground: #ffffff;
--sidebar-accent: #5F8C8E;
--sidebar-accent-foreground: #ffffff;
--sidebar-border: #FFFFFF14;
--sidebar-ring: #C2185B;
--radius: 16px;
}
.dark {
--background: #0f1115;
--foreground: #f8fafc;
--card: #181b22;
--card-foreground: #f8fafc;
--popover: #181b22;
--popover-foreground: #f8fafc;
--primary: #09090A;
--primary-foreground: #ffffff;
--secondary: #252a33;
--secondary-foreground: #f8fafc;
--muted: #252a33;
--muted-foreground: #a1a1aa;
--accent: #C2185B;
--accent-foreground: #ffffff;
--destructive: #C2185B;
--border: #303642;
--input: #303642;
--ring: #C2185B;
--chart-1: #09090A;
--chart-2: #F3F0EA;
--chart-3: #C2185B;
--chart-4: #6F8F72;
--chart-5: #B86A42;
--sidebar: #181b22;
--sidebar-foreground: #f8fafc;
--sidebar-primary: #09090A;
--sidebar-primary-foreground: #ffffff;
--sidebar-accent: #C2185B;
--sidebar-accent-foreground: #ffffff;
--sidebar-border: #303642;
--sidebar-ring: #C2185B;
--radius: 16px;
}
import { Badge } from "@/components/ui/badge";
import { Button } from "@/components/ui/button";
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle,
} from "@/components/ui/card";
import { Input } from "@/components/ui/input";
import { Tabs, TabsList, TabsTrigger } from "@/components/ui/tabs";
export function CyberNoirMangaDossierShadcnKit() {
return (
<section className="grid gap-4 rounded-[var(--radius)] border bg-background p-4 text-foreground">
<div className="flex items-start justify-between gap-4">
<div>
<Badge variant="outline">shadcn/ui</Badge>
<h2 className="mt-3 text-2xl font-semibold tracking-tight">Cyber-Noir Manga Dossier</h2>
<p className="mt-1 max-w-xl text-sm text-muted-foreground">
Use the Katagami registry theme, then compose these shadcn primitives
with the language-specific component recipes.
</p>
</div>
<Button>Apply theme</Button>
</div>
<Tabs defaultValue="components">
<TabsList>
<TabsTrigger value="components">Components</TabsTrigger>
<TabsTrigger value="states">States</TabsTrigger>
<TabsTrigger value="export">Export</TabsTrigger>
</TabsList>
</Tabs>
<Card>
<CardHeader>
<CardTitle>Component recipe</CardTitle>
<CardDescription>
Replace this starter content with the agent-authored product scene
from components.md and preview-shots.json.
</CardDescription>
</CardHeader>
<CardContent className="grid gap-3 sm:grid-cols-[1fr_auto]">
<Input defaultValue="Tokenized shadcn surface" aria-label="Recipe name" />
<Button variant="secondary">Preview state</Button>
</CardContent>
<CardFooter className="justify-between">
<Badge>Ready</Badge>
<Button variant="outline">Copy recipe</Button>
</CardFooter>
</Card>
</section>
);
}
{
"$schema": "https://ui.shadcn.com/schema/registry-item.json",
"name": "cyber-noir-manga-dossier",
"type": "registry:theme",
"title": "Cyber-Noir Manga Dossier shadcn Theme",
"cssVars": {
"theme": {},
"light": {
"background": "#050506",
"foreground": "#F8F5EF",
"card": "#F6F2EA",
"card-foreground": "#F8F5EF",
"popover": "#F6F2EA",
"popover-foreground": "#F8F5EF",
"primary": "#09090A",
"primary-foreground": "#ffffff",
"secondary": "#F3F0EA",
"secondary-foreground": "#111111",
"muted": "#8E8A83",
"muted-foreground": "#F8F5EF",
"accent": "#C2185B",
"accent-foreground": "#ffffff",
"destructive": "#C2185B",
"border": "#FFFFFF14",
"input": "#FFFFFF14",
"ring": "#C2185B",
"chart-1": "#09090A",
"chart-2": "#F3F0EA",
"chart-3": "#C2185B",
"chart-4": "#6F8F72",
"chart-5": "#B86A42",
"sidebar": "#F6F2EA",
"sidebar-foreground": "#F8F5EF",
"sidebar-primary": "#09090A",
"sidebar-primary-foreground": "#ffffff",
"sidebar-accent": "#5F8C8E",
"sidebar-accent-foreground": "#ffffff",
"sidebar-border": "#FFFFFF14",
"sidebar-ring": "#C2185B",
"radius": "16px"
},
"dark": {
"background": "#0f1115",
"foreground": "#f8fafc",
"card": "#181b22",
"card-foreground": "#f8fafc",
"popover": "#181b22",
"popover-foreground": "#f8fafc",
"primary": "#09090A",
"primary-foreground": "#ffffff",
"secondary": "#252a33",
"secondary-foreground": "#f8fafc",
"muted": "#252a33",
"muted-foreground": "#a1a1aa",
"accent": "#C2185B",
"accent-foreground": "#ffffff",
"destructive": "#C2185B",
"border": "#303642",
"input": "#303642",
"ring": "#C2185B",
"chart-1": "#09090A",
"chart-2": "#F3F0EA",
"chart-3": "#C2185B",
"chart-4": "#6F8F72",
"chart-5": "#B86A42",
"sidebar": "#181b22",
"sidebar-foreground": "#f8fafc",
"sidebar-primary": "#09090A",
"sidebar-primary-foreground": "#ffffff",
"sidebar-accent": "#C2185B",
"sidebar-accent-foreground": "#ffffff",
"sidebar-border": "#303642",
"sidebar-ring": "#C2185B",
"radius": "16px"
}
},
"meta": {
"source": "katagami",
"languageId": "cyber-noir-manga-dossier",
"slug": "cyber-noir-manga-dossier",
"componentManifest": [
"button",
"card",
"input",
"textarea",
"select",
"dialog",
"sheet",
"tabs",
"badge",
"separator",
"checkbox",
"switch",
"slider",
"tooltip",
"dropdown-menu",
"table"
],
"installCommand": "npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table",
"nativeTokenNames": {
"borders": [
"accent_width",
"character",
"default_width",
"style"
],
"colors": [
"accent",
"background",
"border",
"error",
"info",
"muted",
"primary",
"secondary",
"success",
"surface",
"text",
"warning"
],
"motion": [
"duration",
"easing",
"philosophy"
],
"radii": [
"full",
"lg",
"md",
"none",
"sm"
],
"shadows": [
"lg",
"md",
"sm"
],
"spacing": [
"base",
"scale"
],
"surfaces": [
"bg_pattern",
"card_style",
"treatment"
],
"typography": [
"base_size",
"body_font",
"google_fonts_url",
"heading_font",
"letter_spacing",
"line_height",
"mono_font",
"scale_ratio"
]
}
}
}
# Cyber-Noir Manga Dossier shadcn/ui Components
Artifact: `component-recipes-v1`
Author: `katagami-ui-projection`
Language ID: `cyber-noir-manga-dossier`
Slug: `cyber-noir-manga-dossier`
## Intent
A polished cyber-noir editorial system for adult near-future interfaces: black-and-white manga pressure, luxury magazine pacing, and terminal diagnostics reduced to surgical magenta interruptions. It treats software as a confidential fashion dossier for an absent body, where scan frames and checksum strings become the ornament.
## Required primitives
- button
- card
- input
- textarea
- select
- dialog
- sheet
- tabs
- badge
- separator
- checkbox
- switch
- slider
- tooltip
- dropdown-menu
- table
Install with `npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table`.
## Token cues
Colors:
{
"accent": "#C2185B",
"background": "#050506",
"border": "#FFFFFF14",
"error": "#C2185B",
"info": "#5F8C8E",
"muted": "#8E8A83",
"primary": "#09090A",
"secondary": "#F3F0EA",
"success": "#6F8F72",
"surface": "#F6F2EA",
"text": "#F8F5EF",
"warning": "#B86A42"
}
Typography:
{
"base_size": "16px",
"body_font": "Saira Condensed",
"google_fonts_url": "https://fonts.googleapis.com/css2?family=Bodoni+Moda:opsz,wght@6..96,600;6..96,800&family=Fragment+Mono:ital@0;1&family=Saira+Condensed:wght@300;400;500;600;700&display=swap",
"heading_font": "Bodoni Moda",
"letter_spacing": "-0.02em",
"line_height": 1.55,
"mono_font": "Fragment Mono",
"scale_ratio": 1.28
}
## Visual character to preserve
- Use full-bleed black and bone-white editorial slabs with sharply offset CSS grid columns and gutters that crop panels at the viewport edge.
- Build manga image zones as monochrome CSS panels using hard borders, halftone radial patterns, diagonal ink cuts, and absolute scan-frame rectangles.
- Place narrow magenta warning tags and OCR-style terminal strings as small absolute-positioned labels crossing gutters, corners, and panel seams.
- Pair oversized condensed editorial display type with compressed sans body captions and a distinct mono diagnostic layer, all tightly tracked.
- Keep Y2K chrome to tiny inset glass strips and port diagrams only, using hairline borders and low-opacity reflections instead of broad gradients.
## ShadSync visual profile
{
"family": "paper-collage",
"material": "paper",
"contour": "default",
"border": "solid",
"underlay": true,
"grain": true,
"stickerBadges": false,
"motion": "still",
"density": "dense",
"accents": [
"primary",
"accent",
"secondary",
"muted"
]
}
## Signature component recipes
### Button
Use `Button` for primary, secondary, outline, and ghost actions. Primary actions must expose the language's strongest contrast pair, while secondary and ghost actions should preserve the surface treatment instead of falling back to default neutral SaaS styling.
### Card
Use `Card`, `CardHeader`, `CardContent`, `CardFooter`, and `CardAction` as the main composition frame. Cards should demonstrate the language's surface, border, hierarchy, and density rules rather than appearing as generic rounded rectangles.
### Input and Textarea
Use `Input` and `Textarea` with visible focus rings, field labels, validation states, and the language's rhythm. Forms should show real product content, not placeholder-only controls.
### Select, Tabs, and Table
Use `Select`, `Tabs`, and `Table` to prove navigation, filtering, and dense data states. The table should show row rhythm, separators, hover/focus states, and an empty or status state when the language calls for it.
### Dialog and Sheet
Use `Dialog` for centered decisions and `Sheet` for contextual editing. Both should inherit the language's spacing, border, overlay, and motion rules.
## Preview shots
- `application-shell`: dashboard or workspace shell with navigation, cards, forms, and state badges.
- `detail-editor`: focused editing flow using input, textarea, select, switch/checkbox, dialog or sheet, and action buttons.
- `data-operations`: table-heavy operational view with tabs, dropdown menu affordances, badges, and destructive/empty states.
- Each preview shot must include a renderable `scene` payload with concrete headline, description, actions, and rows/fields/stats for the UI preview.
## Implementation contract
- Start from local `ui/src/components/ui` shadcn-style primitives; do not create a second component system.
- Apply `/katagami/shadcn/cyber-noir-manga-dossier/registry-theme.json` variables, then use these recipes for composition and state design.
- Preserve Katagami token names as source metadata; shadcn semantic names are only the export surface.
- Do: Use black, bone white, and one surgical magenta accent as the visible palette; keep green or cyan to tiny terminal microtext only.; Crop manga-like panels aggressively and overlay them with scan rectangles, crop marks, and exposure ticks.; Write interface copy as terse dossier evidence: checksum, exposure, port, ghost, frame, null, and warning language.; Give one composition a dominant panel and another a dense diagnostic strip; never make equal cards the main structure.; Use body tracking at -0.02em and display tracking between -0.03em and -0.04em for polished editorial tension.; Preserve square corners and hairline borders unless a small glass port requires the 16px radius token.
- Do not: Do not use rainbow neon cyberpunk, large cyan glows, or colorful anime poster palettes.; Do not create generic dashboard charts, CRM widgets, or three identical cards in a row.; Do not add cute manga stickers, emoji, playful mascots, or childish speech bubbles.; Do not let glassmorphism become the surface language; chrome is only a micro-accent.; Do not rely on stock photography or literal anime screenshots; construct the mood with CSS panels and typography.; Do not soften the system with arbitrary rounded corners, drop-shadow stacks, or friendly app gradients.
## Copy-paste component example
This generated starter proves the import shape. Production Katagami agents should replace it with a language-specific product composition.
```tsx
import { Badge } from "@/components/ui/badge";
import { Button } from "@/components/ui/button";
import {
Card,
CardContent,
CardDescription,
CardFooter,
CardHeader,
CardTitle,
} from "@/components/ui/card";
import { Input } from "@/components/ui/input";
import { Tabs, TabsList, TabsTrigger } from "@/components/ui/tabs";
export function CyberNoirMangaDossierShadcnKit() {
return (
<section className="grid gap-4 rounded-[var(--radius)] border bg-background p-4 text-foreground">
<div className="flex items-start justify-between gap-4">
<div>
<Badge variant="outline">shadcn/ui</Badge>
<h2 className="mt-3 text-2xl font-semibold tracking-tight">Cyber-Noir Manga Dossier</h2>
<p className="mt-1 max-w-xl text-sm text-muted-foreground">
Use the Katagami registry theme, then compose these shadcn primitives
with the language-specific component recipes.
</p>
</div>
<Button>Apply theme</Button>
</div>
<Tabs defaultValue="components">
<TabsList>
<TabsTrigger value="components">Components</TabsTrigger>
<TabsTrigger value="states">States</TabsTrigger>
<TabsTrigger value="export">Export</TabsTrigger>
</TabsList>
</Tabs>
<Card>
<CardHeader>
<CardTitle>Component recipe</CardTitle>
<CardDescription>
Replace this starter content with the agent-authored product scene
from components.md and preview-shots.json.
</CardDescription>
</CardHeader>
<CardContent className="grid gap-3 sm:grid-cols-[1fr_auto]">
<Input defaultValue="Tokenized shadcn surface" aria-label="Recipe name" />
<Button variant="secondary">Preview state</Button>
</CardContent>
<CardFooter className="justify-between">
<Badge>Ready</Badge>
<Button variant="outline">Copy recipe</Button>
</CardFooter>
</Card>
</section>
);
}
```
## Layout notes
{
"breakpoints": ">=1200px cinematic dossier spread; 768-1199px two-column tablet stack with preserved edge crops; <768px single-column vertical title sequence with horizontal diagnostic strips.",
"density": "High contrast between open editorial fields and compact diagnostic clusters; dense zones should occupy less area but carry more microtext.",
"grid": "Desktop uses a 12-column asymmetric grid with 24px gutters and max width around 1480px; key panels span 5, 7, or 9 columns to prevent equal-card rhythm.",
"whitespace": "Use 64-128px voids around title cards and 4-12px gaps inside diagnostic clusters, maintaining at least an 8:1 spacing rhythm."
}
{
"artifact": "katagami:shadcn-preview-shots",
"version": "preview-shots-v1",
"generator": "katagami-ui-compatibility-projection",
"generatedBy": "katagami-ui-projection",
"requiresVisualProfile": true,
"schema": "katagami:shadcn-preview-shots/renderable-v1",
"renderable": true,
"language": {
"id": "cyber-noir-manga-dossier",
"name": "Cyber-Noir Manga Dossier",
"slug": "cyber-noir-manga-dossier"
},
"installCommand": "npx shadcn@latest add button card input textarea select dialog sheet tabs badge separator checkbox switch slider tooltip dropdown-menu table",
"primitives": [
"button",
"card",
"input",
"textarea",
"select",
"dialog",
"sheet",
"tabs",
"badge",
"separator",
"checkbox",
"switch",
"slider",
"tooltip",
"dropdown-menu",
"table"
],
"identityNotes": [
"Use full-bleed black and bone-white editorial slabs with sharply offset CSS grid columns and gutters that crop panels at the viewport edge.",
"Build manga image zones as monochrome CSS panels using hard borders, halftone radial patterns, diagonal ink cuts, and absolute scan-frame rectangles.",
"Place narrow magenta warning tags and OCR-style terminal strings as small absolute-positioned labels crossing gutters, corners, and panel seams.",
"Pair oversized condensed editorial display type with compressed sans body captions and a distinct mono diagnostic layer, all tightly tracked.",
"Keep Y2K chrome to tiny inset glass strips and port diagrams only, using hairline borders and low-opacity reflections instead of broad gradients."
],
"visualProfile": {
"family": "brutalist",
"material": "ink",
"contour": "default",
"border": "solid",
"underlay": true,
"grain": false,
"stickerBadges": false,
"motion": "still",
"density": "dense",
"accents": [
"primary",
"accent",
"secondary",
"muted"
]
},
"shots": [
{
"id": "application-shell",
"title": "Application shell",
"viewport": "desktop",
"primitives": [
"button",
"card",
"input",
"select",
"tabs",
"badge",
"separator",
"table"
],
"composition": "A real product workspace with navigation, summary cards, filtering controls, and one dense content region.",
"mustShow": [
"primary and secondary actions",
"card hierarchy",
"filterable state",
"table or list density"
],
"avoid": [
"component inventory walls",
"placeholder-only content",
"generic rounded SaaS chrome"
],
"scene": {
"eyebrow": "workspace spread",
"headline": "Cyber-Noir Manga Dossier launch room",
"description": "A product team workspace where navigation, filters, metrics, and dense rows carry the language's visible structure.",
"primaryAction": "Apply theme",
"secondaryAction": "Review states",
"stats": [
{
"label": "components",
"value": "16",
"tone": "accent"
},
{
"label": "states",
"value": "ready"
},
{
"label": "density",
"value": "balanced",
"tone": "warning"
}
],
"rows": [
{
"label": "Primary flow",
"value": "mapped",
"status": "active"
},
{
"label": "Token coverage",
"value": "semantic",
"status": "synced"
},
{
"label": "Responsive proof",
"value": "queued",
"status": "review"
}
],
"statuses": [
"Active",
"Synced",
"Draft"
]
}
},
{
"id": "detail-editor",
"title": "Detail editor",
"viewport": "tablet",
"primitives": [
"button",
"card",
"input",
"textarea",
"select",
"checkbox",
"switch",
"slider",
"dialog",
"sheet"
],
"composition": "A focused editing flow with form fields, validation, confirmation, and a contextual side panel.",
"mustShow": [
"focus ring",
"error or destructive state",
"dialog or sheet treatment",
"written guidance content"
],
"avoid": [
"unstyled browser controls",
"floating cards inside cards",
"missing labels"
],
"scene": {
"eyebrow": "editing flow",
"headline": "Language recipe editor",
"description": "A focused form proving labels, validation, toggles, panel rhythm, and action hierarchy.",
"primaryAction": "Save recipe",
"secondaryAction": "Open sheet",
"fields": [
{
"label": "Component family",
"value": "Narrative cards"
},
{
"label": "State treatment",
"value": "Visible focus + validation"
},
{
"label": "Motion",
"value": "Small lift, no opacity-only fade"
}
],
"statuses": [
"Focus",
"Invalid",
"Confirmed"
]
}
},
{
"id": "data-operations",
"title": "Data operations",
"viewport": "mobile",
"primitives": [
"button",
"tabs",
"badge",
"dropdown-menu",
"table",
"tooltip",
"separator"
],
"composition": "A compact operational view proving row rhythm, stacked actions, menu states, badges, and empty/destructive states.",
"mustShow": [
"responsive reflow",
"dense row styling",
"menu affordance",
"status badge system"
],
"avoid": [
"desktop-only tables",
"text overflow",
"default shadcn spacing without Katagami character"
],
"scene": {
"eyebrow": "operations",
"headline": "Compact review queue",
"description": "A narrow viewport scene with rows, menus, tooltips, badges, and destructive affordances.",
"primaryAction": "Resolve",
"secondaryAction": "Filter",
"rows": [
{
"label": "Button hierarchy",
"value": "approved",
"status": "ok"
},
{
"label": "Table rhythm",
"value": "needs pass",
"status": "watch"
},
{
"label": "Empty state",
"value": "designed",
"status": "done"
}
],
"statuses": [
"Queued",
"Blocked",
"Done"
]
}
}
],
"componentRecipes": [
{
"primitive": "button",
"intent": "Prove action hierarchy, focus, disabled, and destructive states."
},
{
"primitive": "card",
"intent": "Carry the language surface, border, elevation, and density rules."
},
{
"primitive": "input",
"intent": "Show labels, focus rings, validation, and spacing rhythm."
},
{
"primitive": "textarea",
"intent": "Show longer guidance, validation copy, and writing density."
},
{
"primitive": "select",
"intent": "Show filtering, selection contrast, and menu trigger styling."
},
{
"primitive": "dialog",
"intent": "Show centered decision states and overlay treatment."
},
{
"primitive": "sheet",
"intent": "Show contextual side panels and responsive editing."
},
{
"primitive": "tabs",
"intent": "Show navigational structure and active/inactive contrast."
},
{
"primitive": "badge",
"intent": "Show compact status vocabulary and semantic colors."
},
{
"primitive": "separator",
"intent": "Show section rhythm without generic gray dividers."
},
{
"primitive": "checkbox",
"intent": "Show binary selection with visible focus and checked states."
},
{
"primitive": "switch",
"intent": "Show settings toggles and on/off contrast."
},
{
"primitive": "slider",
"intent": "Show numeric adjustment with track/thumb styling."
},
{
"primitive": "tooltip",
"intent": "Show concise explanation styling above compact controls."
},
{
"primitive": "dropdown-menu",
"intent": "Show action menus, destructive items, and grouped choices."
},
{
"primitive": "table",
"intent": "Show dense operational data, separators, row states, and responsive behavior."
}
],
"qualityRules": {
"do": [
"Use black, bone white, and one surgical magenta accent as the visible palette; keep green or cyan to tiny terminal microtext only.",
"Crop manga-like panels aggressively and overlay them with scan rectangles, crop marks, and exposure ticks.",
"Write interface copy as terse dossier evidence: checksum, exposure, port, ghost, frame, null, and warning language.",
"Give one composition a dominant panel and another a dense diagnostic strip; never make equal cards the main structure.",
"Use body tracking at -0.02em and display tracking between -0.03em and -0.04em for polished editorial tension.",
"Preserve square corners and hairline borders unless a small glass port requires the 16px radius token."
],
"dont": [
"Do not use rainbow neon cyberpunk, large cyan glows, or colorful anime poster palettes.",
"Do not create generic dashboard charts, CRM widgets, or three identical cards in a row.",
"Do not add cute manga stickers, emoji, playful mascots, or childish speech bubbles.",
"Do not let glassmorphism become the surface language; chrome is only a micro-accent.",
"Do not rely on stock photography or literal anime screenshots; construct the mood with CSS panels and typography.",
"Do not soften the system with arbitrary rounded corners, drop-shadow stacks, or friendly app gradients."
]
}
}