skills/north/SKILL.md
Standards and process for building modern web projects with AI. Content-first, mobile-first, component-based methodology. Use when starting a new project, creating features, designing components, making architecture decisions, or when the user asks to build something for the web.
npx skillsauth add razbakov/skills northInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
A content-first, mobile-first, component-based methodology for building modern web projects. Adapted from North standards, updated for AI-driven development.
Core belief: AI generates code. Humans define intent. The better the intent, the better the output. North is how you define intent.
Follow this sequence. Never skip a step. Each step feeds the next.
Before anything — answer these questions in one paragraph:
Without a vision statement, every AI prompt is a shot in the dark.
Define 2-4 personas based on how people use the product, not demographics.
Each persona needs:
Don't stereotype. Don't assume mobile users are rushed. Don't assume desktop users want more. Users are the same people on every device.
Model your content types BEFORE any design or code. Each content type needs:
Content lives longer than any presentation. Never tie content to a specific device, layout, or platform. No "mobile title" or "desktop image" — build systems of content with small/medium/large variants.
Determine what content goes where and why. Rules:
The page metaphor is dead. Design reusable components and layouts, not pages.
Design tokens (colors, spacing, typography scales) ensure consistency across all components.
Work in 2-week sprints. Each sprint:
Users come for content. Everything else is decoration. Content is the most basic need — if it fails, nothing else matters.
Website Hierarchy of Needs (bottom to top):
Each layer depends on the one below. Never sacrifice a lower layer for a higher one.
Not "design for phones." Use mobile as a focusing lens:
Start with semantic HTML. Layer CSS. Layer JS. Every layer is optional.
@supports for CSS feature detection<picture> and srcset for responsive imagesEvery design decision has a performance cost. Measure it.
Targets (Core Web Vitals):
Rules:
No "mobile site" vs "desktop site." One codebase. One URL. Responsive by default. Never hide content based on screen size. Never assume capabilities from viewport width.
When creating tasks:
As [persona], I want [desire] so that [rationale].
Requirements:
- [Specific, buildable requirement]
- [Another requirement]
- [Acceptance criteria]
Component: [which component this affects]
Content type: [which content model this uses]
Before shipping any feature:
development
Seed a new or empty Instagram account with a 9-post grid (3×3) so the profile looks established the moment a new visitor lands. Designed for festivals, new businesses, product launches, conferences, communities — any time an empty IG profile would hurt conversion from external traffic (QR scans, flyer drops, cross-promo). Generates assets via /image-from-gemini (per content-publishing rules — never HTML), writes captions with hashtag sets, and outputs a posting order + cadence plan. Trigger generously: phrases like '9 posts for instagram', 'fill my IG', 'starter grid', 'launch grid', 'instagram seed', '9-post grid', 'IG account not to look empty', 'first instagram posts', 'feed bootstrap', '3x3 grid', 'instagram launch content'. Even if the user mentions only one piece (just the images, just the captions, just the order), use this skill — the grid only works as an integrated bundle.
testing
Translate one English blog post into multiple target languages via parallel sub-agents, preserving frontmatter conventions, hero image, and brand voice. Use when the user shares a published English post URL or markdown path and says 'translate it', 'add other languages', 'publish in DE/ES/RU/UK', 'translate to 5 languages', or asks for localized versions of a specific post.
development
Build a complete press kit for an event, product launch, or campaign — in multiple languages — and publish it as a shareable Google Drive folder ready to send to journalists, partners, or a delegate. Produces press releases (typically DE/EN/ES, or configurable), uploads press photos and flyers, creates an Overview document for at-a-glance briefing, and creates a Handover document with pending tasks, contacts, risks, and decisions so press distribution can be delegated. Use when the user says 'I need a press release', 'create a press kit', 'press release in X languages', 'set up a Drive folder for press', 'handover doc for someone else to run press', or has an upcoming announcement that needs to be sent to media. Trigger generously: even partial requests (just a press release, just a flyer folder) typically evolve into the full kit.
development
Track ticket sales for a live event (concert, festival, conference, workshop) with daily snapshots, generate a burndown chart comparing actual sales to ideal-linear targets and tier-cumulative milestones, and report whether the event is on pace. Use when the user asks how sales are going, wants to know if their event will sell out, asks for a daily sales report, wants to set up sales tracking for an upcoming event, or asks about ticket pace / velocity / projection. Trigger generously: phrases like 'how is concert sales going', 'burndown for my event', 'are we going to sell out', 'sales velocity', 'daily ticket chart', 'how many tickets do we need to sell', or any case where the user has a ticketed event with a fixed sales window and wants visibility on pacing.