# Design System Master File > **LOGIC:** When building a specific page, first check `design-system/pages/[page-name].md`. > If that file exists, its rules **override** this Master file. > If not, strictly follow the rules below. --- **Project:** Bookshelf App **Generated:** 2026-02-07 13:01:29 **Category:** Design System/Component Library --- ## Global Rules ### Color Palette | Role | Hex | CSS Variable | |------|-----|--------------| | Primary | `#0891B2` | `--color-primary` | | Secondary | `#22D3EE` | `--color-secondary` | | CTA/Accent | `#22C55E` | `--color-cta` | | Background | `#ECFEFF` | `--color-background` | | Text | `#164E63` | `--color-text` | **Color Notes:** Fresh cyan + clean green ### Typography - **Heading Font:** Inter - **Body Font:** Inter - **Mood:** minimal, clean, swiss, functional, neutral, professional - **Google Fonts:** [Inter + Inter](https://fonts.google.com/share?selection.family=Inter:wght@300;400;500;600;700) **CSS Import:** ```css @import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap'); ``` ### Spacing Variables | Token | Value | Usage | |-------|-------|-------| | `--space-xs` | `4px` / `0.25rem` | Tight gaps | | `--space-sm` | `8px` / `0.5rem` | Icon gaps, inline spacing | | `--space-md` | `16px` / `1rem` | Standard padding | | `--space-lg` | `24px` / `1.5rem` | Section padding | | `--space-xl` | `32px` / `2rem` | Large gaps | | `--space-2xl` | `48px` / `3rem` | Section margins | | `--space-3xl` | `64px` / `4rem` | Hero padding | ### Shadow Depths | Level | Value | Usage | |-------|-------|-------| | `--shadow-sm` | `0 1px 2px rgba(0,0,0,0.05)` | Subtle lift | | `--shadow-md` | `0 4px 6px rgba(0,0,0,0.1)` | Cards, buttons | | `--shadow-lg` | `0 10px 15px rgba(0,0,0,0.1)` | Modals, dropdowns | | `--shadow-xl` | `0 20px 25px rgba(0,0,0,0.15)` | Hero images, featured cards | --- ## Component Specs ### Buttons ```css /* Primary Button */ .btn-primary { background: #22C55E; color: white; padding: 12px 24px; border-radius: 8px; font-weight: 600; transition: all 200ms ease; cursor: pointer; } .btn-primary:hover { opacity: 0.9; transform: translateY(-1px); } /* Secondary Button */ .btn-secondary { background: transparent; color: #0891B2; border: 2px solid #0891B2; padding: 12px 24px; border-radius: 8px; font-weight: 600; transition: all 200ms ease; cursor: pointer; } ``` ### Cards ```css .card { background: #ECFEFF; border-radius: 12px; padding: 24px; box-shadow: var(--shadow-md); transition: all 200ms ease; cursor: pointer; } .card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); } ``` ### Inputs ```css .input { padding: 12px 16px; border: 1px solid #E2E8F0; border-radius: 8px; font-size: 16px; transition: border-color 200ms ease; } .input:focus { border-color: #0891B2; outline: none; box-shadow: 0 0 0 3px #0891B220; } ``` ### Modals ```css .modal-overlay { background: rgba(0, 0, 0, 0.5); backdrop-filter: blur(4px); } .modal { background: white; border-radius: 16px; padding: 32px; box-shadow: var(--shadow-xl); max-width: 500px; width: 90%; } ``` --- ## Style Guidelines **Style:** Exaggerated Minimalism **Keywords:** Bold minimalism, oversized typography, high contrast, negative space, loud minimal, statement design **Best For:** Fashion, architecture, portfolios, agency landing pages, luxury brands, editorial **Key Effects:** font-size: clamp(3rem 10vw 12rem), font-weight: 900, letter-spacing: -0.05em, massive whitespace ### Page Pattern **Pattern Name:** Minimal Single Column - **Conversion Strategy:** Single CTA focus. Large typography. Lots of whitespace. No nav clutter. Mobile-first. - **CTA Placement:** Center, large CTA button - **Section Order:** 1. Hero headline, 2. Short description, 3. Benefit bullets (3 max), 4. CTA, 5. Footer --- ## Anti-Patterns (Do NOT Use) - ❌ Poor documentation - ❌ No live preview ### Additional Forbidden Patterns - ❌ **Emojis as icons** — Use SVG icons (Heroicons, Lucide, Simple Icons) - ❌ **Missing cursor:pointer** — All clickable elements must have cursor:pointer - ❌ **Layout-shifting hovers** — Avoid scale transforms that shift layout - ❌ **Low contrast text** — Maintain 4.5:1 minimum contrast ratio - ❌ **Instant state changes** — Always use transitions (150-300ms) - ❌ **Invisible focus states** — Focus states must be visible for a11y --- ## Pre-Delivery Checklist Before delivering any UI code, verify: - [ ] No emojis used as icons (use SVG instead) - [ ] All icons from consistent icon set (Heroicons/Lucide) - [ ] `cursor-pointer` on all clickable elements - [ ] Hover states with smooth transitions (150-300ms) - [ ] Light mode: text contrast 4.5:1 minimum - [ ] Focus states visible for keyboard navigation - [ ] `prefers-reduced-motion` respected - [ ] Responsive: 375px, 768px, 1024px, 1440px - [ ] No content hidden behind fixed navbars - [ ] No horizontal scroll on mobile