Tier: M (2-4 days) Type: perf
Context
Site is small but Core Web Vitals never measured. Google Fonts CDN is blocking, no font subsetting, no critical CSS inlining. Set explicit budgets and hit them.
Scope
Baseline + optimize:
- Run Lighthouse + PageSpeed Insights, capture in
docs/PERF.md
- Target: 95+ on all four axes (Perf / A11y / Best Practices / SEO), mobile + desktop
- Font subsetting (only used weights of Space Grotesk, Inter, JetBrains Mono)
font-display: swap, self-host fonts, preload critical files
- Image optimization (logo, og-image)
- Inline critical CSS for above-the-fold
- Tree-shake Tailwind
- CI Lighthouse job posting score comments on PRs
Acceptance criteria
Files to start with
index.html, src/index.css
vite.config.ts
Tier: M (2-4 days) Type: perf
Context
Site is small but Core Web Vitals never measured. Google Fonts CDN is blocking, no font subsetting, no critical CSS inlining. Set explicit budgets and hit them.
Scope
Baseline + optimize:
docs/PERF.mdfont-display: swap, self-host fonts, preload critical filesAcceptance criteria
docs/PERF.mdbaseline + post-fixFiles to start with
index.html,src/index.cssvite.config.ts