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.
3.08 s
Largest Contentful Paint Largest Contentful Paint — how long until the largest visible element loads. Under 2.5s is good.
12.20 s
Total Blocking Time Total Blocking Time — total time the main thread was blocked, preventing user input. Under 200ms is good.
1.38 s
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.
5.77 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.
12.23 s
Page Load Progression
DThird-Party ImpactAction100% third-party, 0 ms blockingFIX
FJS Execution CostAction5154ms total JS executionFIX
Main Thread Breakdown
| Script | Total | Scripting | Parse/Compile | Party |
|---|---|---|---|---|
| https://www.flipsnack.com/ | 1639ms | 33ms | 3ms | 3rd |
| Unattributable | 974ms | 18ms | 0ms | 3rd |
| https://www.googletagmanager.com/gtag/js?id=G-XT3P0H8SMY&l=dataLayerForGoogleTagManager&cx=c>m=4e64h1 | 695ms | 597ms | 89ms | 3rd |
| https://cdn.flipsnack.com/site/dist/genericv2.dbd387c09f8de4b79849.js | 410ms | 109ms | 36ms | 3rd |
| https://www.googletagmanager.com/gtm.js?id=GTM-T8CXXNC&l=dataLayerForGoogleTagManager | 398ms | 308ms | 84ms | 3rd |
| https://www.googletagmanager.com/gtag/js?id=AW-928025474&l=dataLayerForGoogleTagManager&cx=c>m=4e64h1 | 304ms | 222ms | 79ms | 3rd |
| https://cdn.flipsnack.com/site/accessibility.min.js | 268ms | 170ms | 20ms | 3rd |
| https://cdn.flipsnack.com/site/dist/site-base.44ae0c81dcd683c648a9.js | 268ms | 196ms | 33ms | 3rd |
| https://player.flipsnack.com/reader-bridge.gz.js | 199ms | 63ms | 133ms | 3rd |
DPage Weight InventoryAction69 resources · 1.5 MB · 272 KB savings availableFIX
~272.3 KiB of savings available
| # | Resource | Type | Size | Cache | Unused | 3rd party | Issues |
|---|---|---|---|---|---|---|---|
| — | — | ||||||
| 69 resources | 1.5 MiB | ||||||
FHTTP CachingActionNo cache headersFIX
No Cache-Control header
Adding a Cache-Control header can significantly improve repeat-visit performance.
BPage Weight Budget1.5 MB transferred, 69 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
BImage Optimization46 images, 0 KB saveableREVIEW
CJS BundlesAction7 scripts, 272 KB unusedREVIEW
Downloaded but never executed on this page.
| Script | Size | Unused | Minified | Party |
|---|---|---|---|---|
| https://www.googletagmanager.com/gtag/js?id=G-XT3P0H8SMY&l=dataLayerForGoogleTagManager&cx=c>m=4e64h1 | 180 KB | 70 KB (39%) | ✓ | 3rd |
| https://www.googletagmanager.com/gtm.js?id=GTM-T8CXXNC&l=dataLayerForGoogleTagManager | 161 KB | 70 KB (43%) | ✓ | 3rd |
| https://www.googletagmanager.com/gtag/js?id=AW-928025474&l=dataLayerForGoogleTagManager&cx=c>m=4e64h1 | 147 KB | 65 KB (44%) | ✓ | 3rd |
| https://cdn.flipsnack.com/site/dist/genericv2.dbd387c09f8de4b79849.js | 52 KB | 34 KB (67%) | ✓ | 3rd |
| https://cdn.flipsnack.com/site/dist/site-base.44ae0c81dcd683c648a9.js | 51 KB | 32 KB (63%) | ✓ | 3rd |
| https://cdn.flipsnack.com/site/accessibility.min.js | 30 KB | — | ✓ | 3rd |
| https://player.flipsnack.com/reader-bridge.gz.js | 187 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
CGreen HostingActionWhether the site is served from green-energy infrastructureREVIEW
Green Hosting
No green hosting detected
A+Text CompressionAll text resources are compressedPASS
A+Font Loading7 fonts (115 KB)PASS
Web fonts
7
115 KB total
Render-blocking
0
of 7
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 Hints7 hints, 0 missing preconnectsPASS
Current Resource Hints
7 resource hints configured
A+Render-Blocking ResourcesNo render-blocking resources detectedPASS
A+Third-Party ResourcesNo third-party resources detectedPASS
Network Waterfall69 requests over 2539msINFO
Third-Party Script CostPer-script blocking time, transfer cost, and cache headersINFO
| Script | Category | Execution | Transfer | Unused | Monthly Cost | Verdict |
|---|---|---|---|---|---|---|
www.flipsnack.com www.flipsnack.com | Other | 1639ms | 26 KB | — | $22/mo | Costly |
Unattributable Unattributable | Other | 974ms | 0 KB | — | $13/mo | Costly |
Google Tag Manager www.googletagmanager.com | Tag Manager | 695ms | 180 KB | 39% | $9/mo | Costly |
cdn.flipsnack.com cdn.flipsnack.com | Other | 410ms | 52 KB | 67% | $5/mo | Costly |
Google Tag Manager www.googletagmanager.com | Tag Manager | 398ms | 161 KB | 43% | $5/mo | Costly |
Google Tag Manager www.googletagmanager.com | Tag Manager | 304ms | 147 KB | 44% | $4/mo | Costly |
cdn.flipsnack.com cdn.flipsnack.com | Other | 268ms | 30 KB | — | $4/mo | Costly |
cdn.flipsnack.com cdn.flipsnack.com | Other | 268ms | 51 KB | 63% | $4/mo | Costly |
player.flipsnack.com player.flipsnack.com | Other | 199ms | 187 KB | — | $3/mo | Optional |
These scripts may cost more than they're worth
- www.flipsnack.com adds 1639ms and costs ~$22/month
- Unattributable adds 974ms and costs ~$13/month
- Google Tag Manager adds 695ms and costs ~$9/month
- cdn.flipsnack.com adds 410ms and costs ~$5/month
- Google Tag Manager adds 398ms and costs ~$5/month
- Google Tag Manager adds 304ms and costs ~$4/month
- cdn.flipsnack.com adds 268ms and costs ~$4/month
- cdn.flipsnack.com adds 268ms and costs ~$4/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
www.flipsnack.com takes 1639ms 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 974ms 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 695ms 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
cdn.flipsnack.com takes 410ms 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
67% of cdn.flipsnack.com'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
Google Tag Manager takes 398ms 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 304ms 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
cdn.flipsnack.com takes 268ms 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
cdn.flipsnack.com takes 268ms 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
63% of cdn.flipsnack.com'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