Performance
· 15 checks — Lighthouse + waterfall + sustainability rolled into one auditable list.Performance-focused optimization plan with CWV assessment, top offenders, and time estimates
First Contentful Paint First Contentful Paint — how long until the browser renders the first piece of content. Under 1.8s is good.
475 ms
Largest Contentful Paint Largest Contentful Paint — how long until the largest visible element loads. Under 2.5s is good.
1.02 s
Total Blocking Time Total Blocking Time — total time the main thread was blocked, preventing user input. Under 200ms is good.
32 ms
Cumulative Layout Shift Cumulative Layout Shift — measures visual stability. How much the page layout shifts during loading. Under 0.1 is good.
0.000
Speed Index Speed Index — how quickly content is visually displayed during load. Under 3.4s is good.
475 ms
Time to Interactive Time to Interactive — how long until the page is fully interactive and responds to user input. Under 3.8s is good.
1.02 s
Page Load Progression
DThird-Party ImpactAction81% third-party, 0 ms blockingFIX
BJS Bundles5 scripts, 122 KB unusedREVIEW
Downloaded but never executed on this page.
| Script | Size | Unused | Minified | Party |
|---|---|---|---|---|
| https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js | 251 KB | 122 KB (49%) | ✓ | 3rd |
| https://polyfill.io/v3/polyfill.min.js?features=es6 | 0 KB | — | ✓ | 3rd |
| https://yaml.org/assets/javascripts/bundle.50899def.min.js | 33 KB | — | ✓ | 1st |
| https://yaml.org/js/mathjax.js | 3 KB | — | ✓ | 1st |
| https://yaml.org/assets/javascripts/workers/search.d50fe291.min.js | 0 KB | — | ✓ | 1st |
Consider code splitting or tree shaking to reduce unused code.
This bundle has high unused code — code-split or tree-shake to ship only what executes.
Source: web.dev / Lighthouse coverage
CGreen HostingActionWhether the site is served from green-energy infrastructureREVIEW
Green Hosting
No green hosting detected
A+Page Weight Budget404 KB transferred, 17 requestsPASS
A+Text CompressionAll text resources are compressedPASS
AImage Optimization1 images, 0 KB saveablePASS
Set explicit width and height to prevent CLS.
Image without explicit width/height — browser can't reserve space; CLS jumps when image loads.
Source: web.dev / Core Web Vitals
A+JS Execution Cost144ms total JS executionPASS
Main Thread Breakdown
| Script | Total | Scripting | Parse/Compile | Party |
|---|---|---|---|---|
| https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js | 88ms | 64ms | 22ms | 3rd |
| https://yaml.org/assets/javascripts/bundle.50899def.min.js | 56ms | 26ms | 2ms | 1st |
A+Font Loading2 fonts (69 KB)PASS
Web fonts
2
69 KB total
Render-blocking
0
of 2
Dominant font-display
swap
Most common across fonts
Font loading timeline
Optimization checklist
- Preload critical fonts (priority=high)
- Use woff2 format for all fonts
- Set font-display to swap, optional, or fallback
- Subset large fonts (≤100 KB each)
A+Resource CachingAll resources properly cachedPASS
A+Critical Rendering PathNo render-blocking resourcesPASS
A+Resource HintsNo optimization neededPASS
APage Weight Inventory17 resources · 404 KB · 122 KB savings availablePASS
~121.7 KiB of savings available
| # | Resource | Type | Size | Cache | Unused | 3rd party | Issues |
|---|---|---|---|---|---|---|---|
| — | — | ||||||
| 17 resources | 404.2 KiB | ||||||
A+HTTP Cachingmax-age=600 (10 minutes)PASS
max-age=600
| Directive | Value | Meaning |
|---|---|---|
| max-age | 600 | Cache for 10 minutes |
Network Waterfall17 requests over 258msINFO
Third-Party Script CostPer-script blocking time, transfer cost, and cache headersINFO
| Script | Category | Execution | Transfer | Unused | Monthly Cost | Verdict |
|---|---|---|---|---|---|---|
jsDelivr cdn.jsdelivr.net | CDN | 88ms | 251 KB | 49% | $1/mo | Optional |
61% of JavaScript execution time comes from third-party scripts.
Third-party scripts (analytics, ads, social, A/B testing) often dominate execution time — every one is a perf-and-privacy tax.
Learn more ▾ ▴
Each third-party script is a black box: you don't control when it loads, what it executes, or how much it grows. They often account for a major share of total blocking time on average sites (HTTP Archive's Web Almanac documents the trend). Audit which ones you actually need, defer the rest, and use facade patterns (lite-youtube, lite-vimeo) for embedded media.
Source: web.dev / HTTP Archive Web Almanac