about.micr.dev · desktop-only personal archive
Personal portfolio/about page for micr.dev. Part portfolio, part personal archive — a static site listing interests, tastes, and references in a two-column layout.
- HTML/CSS/JS — vanilla, no frameworks, no build tools
- Custom font — DecimaMono (self-hosted)
- Data-driven — all content lives in
data.json, rendered client-side - Hosted on Netlify
Desktop browsers only. The site uses a fixed two-column layout at ≥1024px width. Mobile visitors see a blocker overlay with a message to visit on desktop.
.
├── index.html # Main page (skeleton loader, two-column layout)
├── script.js # Fetches data.json, renders all content sections
├── style.css # Layout, skeleton shimmer, grids, custom cursor
├── data.json # All profile content (intro, series, music, etc.)
├── fonts/
│ └── DecimaMono.ttf # Primary monospace font (preloaded)
├── images/ # Game covers, album art, designer logos, hero image
├── .claude/
│ └── skills/ # Claude Code skill constraints for UI work
├── favicon.png
├── robots.txt
├── sitemap.xml
└── netlify.toml # Netlify build config (publish = ".")
index.htmlloads with skeleton placeholder UI (shimmer animation while content loads).script.jswaits for fonts and the hero image, then fetchesdata.json.- Content is rendered dynamically based on each section's
type:intro— bio text with name headerT— timed items (title + year), sorted by yearR— rows with dot leaders (title·········right), optional linksP— picture grid (album art, game covers), optional Spotify linksdesignerImages— fashion designer logo gridcolours— hex values with inline color swatchesfonts— font name rows with dot leadersrunways— runway show rowslastUpdated— footer timestamp
- A custom floating cursor shows labels on image hover.
- Desktop-only — mobile visitors see a blocker overlay.
No build step required. Serve the directory with any static file server:
# Python
python3 -m http.server 8000
# Node (if npx available)
npx serve .
# PHP
php -S localhost:8000Open http://localhost:8000 in your browser.
All content is in data.json. Edit it directly to add, remove, or reorder sections. The file is a JSON object where each top-level key is a section. The displayName field controls the section heading (defaults to the key name).
| Type | Fields | Display |
|---|---|---|
intro |
text |
Bio paragraph |
T |
items[].title, items[].year |
Title·········Year |
R |
items[].title, items[].right?, items[].spotify?, items[].link? |
Title·········Right |
P |
items[].name, items[].image?, items[].spotify? |
Image grid |
designerImages |
items[].name, items[].image? |
Logo grid |
colours |
items[].title (hex) |
Hex·········[swatch] |
fonts |
items[].title, items[].right |
Font·········Right |
runways |
items[].runway, items[].designer |
Runway·········Designer |
lastUpdated |
text |
Small footer text |
Each section uses displayName for its heading (defaults to the object key). Add new images to images/ and reference them by filename.
CSS variables in style.css (:root) control column widths and positioning:
--left-col-min: 480px;
--left-col-ideal: 36vw;
--left-col-max: 880px;Configured via netlify.toml:
[build]
publish = "."Push to the repository's main branch — Netlify auto-deploys from the root directory with no build command.
This project includes a Claude Code skill (ui-skills) that enforces opinionated UI constraints when working with AI coding agents. Invoke it with /ui-skills in Claude Code to apply layout, animation, typography, and accessibility rules to any changes.
All rights reserved.