Performance
· 17 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.
1.96 s
Largest Contentful Paint Largest Contentful Paint — how long until the largest visible element loads. Under 2.5s is good.
7.82 s
Total Blocking Time Total Blocking Time — total time the main thread was blocked, preventing user input. Under 200ms is good.
426 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.
3.43 s
Time to Interactive Time to Interactive — how long until the page is fully interactive and responds to user input. Under 3.8s is good.
7.85 s
Page Load Progression
DThird-Party ImpactAction100% third-party, 0 ms blockingFIX
BPage Weight Budget1.1 MB transferred, 67 requestsREVIEW
Large JavaScript bundles delay interactivity. Split code by route or defer non-critical scripts.
JavaScript bundle is large — code-split routes and lazy-load off-screen components to defer.
Source: web.dev
Subset fonts to include only used characters, or switch to system font stacks.
Font payload is large — subset to used glyphs only, or fall back to system fonts (zero load time).
Source: web.dev font loading
BImage Optimization34 images, 0 KB saveableREVIEW
CJS Execution CostAction1878ms total JS executionREVIEW
Main Thread Breakdown
| Script | Total | Scripting | Parse/Compile | Party |
|---|---|---|---|---|
| https://react.dev/_next/static/chunks/framework-76ad44d61c11f057.js | 504ms | 439ms | 15ms | 3rd |
| https://react.dev/ | 438ms | 21ms | 7ms | 3rd |
| Unattributable | 346ms | 13ms | 0ms | 3rd |
| https://www.googletagmanager.com/gtag/js?id=G-B1E83PJ3RT | 262ms | 221ms | 39ms | 3rd |
| https://react.dev/_next/static/chunks/4ad82c5e.aa059996e264f809.js | 143ms | 131ms | 12ms | 3rd |
| https://react.dev/_next/static/chunks/main-8bc660a98b463b2d.js | 97ms | 86ms | 11ms | 3rd |
| https://react.dev/_next/static/chunks/pages/%5B%5B...markdownPath%5D%5D-ef91ae665155f68d.js | 88ms | 86ms | 1ms | 3rd |
CJS BundlesAction13 scripts, 209 KB unusedREVIEW
Downloaded but never executed on this page.
| Script | Size | Unused | Minified | Party |
|---|---|---|---|---|
| https://www.googletagmanager.com/gtag/js?id=G-B1E83PJ3RT | 146 KB | 62 KB (43%) | ✓ | 3rd |
| https://react.dev/_next/static/chunks/4ad82c5e.aa059996e264f809.js | 50 KB | 45 KB (90%) | ✓ | 3rd |
| https://react.dev/_next/static/chunks/811.b2e5ca620a3f883e.js | 110 KB | 44 KB (40%) | ✓ | 3rd |
| https://react.dev/_next/static/chunks/928-e89de0bd2e20fa8c.js | 94 KB | 32 KB (34%) | ✓ | 3rd |
| https://react.dev/_next/static/chunks/668-9be9de6fa7660277.js | 34 KB | 26 KB (76%) | ✓ | 3rd |
| https://react.dev/_next/static/chunks/main-8bc660a98b463b2d.js | 39 KB | — | ✓ | 3rd |
| https://react.dev/_next/static/chunks/pages/_app-6d7b64b3b21a9551.js | 1 KB | — | ✓ | 3rd |
| https://react.dev/_next/static/chunks/pages/%5B%5B...markdownPath%5D%5D-ef91ae665155f68d.js | 3 KB | — | ✓ | 3rd |
| https://react.dev/_next/static/MNWyTLE_bcVMjrXmgoiBA/_buildManifest.js | 1 KB | — | ✓ | 3rd |
| https://react.dev/_next/static/MNWyTLE_bcVMjrXmgoiBA/_ssgManifest.js | 0 KB | — | ✓ | 3rd |
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
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
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
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
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
BPage Weight Inventory67 resources · 1.1 MB · 209 KB savings availableREVIEW
~208.7 KiB of savings available
| # | Resource | Type | Size | Cache | Unused | 3rd party | Issues |
|---|---|---|---|---|---|---|---|
| — | — | ||||||
| 67 resources | 1.1 MiB | ||||||
CGreen HostingActionWhether the site is served from green-energy infrastructureREVIEW
Green Hosting
No green hosting detected
BHTTP Cachingpublic, max-age=0, must-revalidateREVIEW
public, max-age=0, must-revalidate
| Directive | Value | Meaning |
|---|---|---|
| public | — | Any cache may store this response |
| max-age | 0 | Cache for 0 seconds |
| must-revalidate | — | Must recheck with server after expiry |
A+Text CompressionAll text resources are compressedPASS
A+Font Loading9 fonts (314 KB)PASS
Web fonts
9
314 KB total
Render-blocking
0
of 9
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 Hints38 hints, 0 missing preconnectsPASS
Current Resource Hints
38 resource hints configured
A+Render-Blocking ResourcesNo render-blocking resources detectedPASS
A+Third-Party ResourcesNo third-party resources detectedPASS
Network Waterfall67 requests over 1386msINFO
Third-Party Script CostPer-script blocking time, transfer cost, and cache headersINFO
| Script | Category | Execution | Transfer | Unused | Monthly Cost | Verdict |
|---|---|---|---|---|---|---|
react.dev react.dev | Other | 504ms | 57 KB | — | €5/mo | Costly |
react.dev react.dev | Other | 438ms | 43 KB | — | €5/mo | Costly |
Unattributable Unattributable | Other | 346ms | 0 KB | — | €4/mo | Costly |
Google Tag Manager www.googletagmanager.com | Tag Manager | 262ms | 146 KB | 43% | €3/mo | Costly |
react.dev react.dev | Other | 143ms | 50 KB | 90% | €2/mo | Optional |
react.dev react.dev | Other | 97ms | 39 KB | — | €1/mo | Optional |
react.dev react.dev | Other | 88ms | 3 KB | — | €1/mo | Optional |
These scripts may cost more than they're worth
- react.dev adds 504ms and costs ~€5/month
- react.dev adds 438ms and costs ~€5/month
- Unattributable adds 346ms and costs ~€4/month
- Google Tag Manager adds 262ms and costs ~€3/month
100% of JavaScript execution time is spent on third-party scripts. Consider auditing which scripts are essential.
When third-party JS execution time exceeds your own, performance gains from frontend work are capped by code you don't own.
Learn more ▾ ▴
Every millisecond of third-party JS competes with your own for main-thread time. If their share is bigger than yours, optimization on your code base barely moves the needle. Audit, defer, or remove third-parties before further frontend optimization. Use Lighthouse's third-party audit to identify the worst offenders.
Source: web.dev
react.dev takes 504ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
react.dev takes 438ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
Unattributable takes 346ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
Google Tag Manager takes 262ms of CPU time. Consider loading it asynchronously or replacing it with a lighter alternative.
This script has high main-thread execution time — optimize hot paths or defer.
Source: web.dev
90% of react.dev's code is unused. The script may be loading features you don't use.
Bundle has high unused-code ratio — tree-shaking and route-splitting recover the wasted bytes.
Source: web.dev