Site teardown · Flexrocksrollovers

Flexrocksrollovers: a phone-and-desktop teardown

We loaded https://flexrocksrollovers.com 4 times on a simulated iPhone and 2 more on a 1366px desktop, and wrote down what a real visitor would see on each. No login, no insider access, no Harvv pixel needed. Here is what repeated visits already show, sorted by how we know it.

June 29, 2026·External scan·4 mobile + 2 desktop loads · no pixel data·Download as PDF

TL;DRWhat jumped out

Of everything we found on this scan, this is the one to start with: Tiny buttons are hard to tap on mobile. 31 of 63 tappable items on this page come in below 44×44 pixels, the minimum size Apple and Google recommend for reliable tapping, and the same ones came up small on every test load. When visitors can't hit what they expect to, they get frustrated and many of them leave instead of trying again.

Below: what's already working, every finding ranked by impact and tagged with the screen it affects, the speed numbers on phone and desktop, and a checklist of what to fix first.

00What's already working

Start here so the problems below are in context. These held up across the test loads:

  • Speed is good. The main content paints in about 1.0s in our test loads, inside Google's 2.5s "good" threshold. Real networks are slower, but the page itself is not heavy.
  • Search basics are in place. Lighthouse scores SEO 100/100. The fundamentals Google looks for are present.
  • Layout holds on phone and desktop. Nothing spilled past the edge at either 390px (phone) or 1366px (desktop), so the structure is responsive.

01Findings, ranked by what hurts conversion most

SeverityFindingHow we know
HighTiny buttons are hard to tap on mobileMobileAccessibility (WCAG)Conversion
31 of 63 tappable items on this page come in below 44×44 pixels, the minimum size Apple and Google recommend for reliable tapping, and the same ones came up small on every test load. When visitors can't hit what they expect to, they get frustrated and many of them leave instead of trying again.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
HighGoogle Analytics tracking brokenBoth
The Google Analytics request failed to complete on every one of the 4 test loads. If real visitors hit the same failure, GA is missing those visits and the dashboard has no way to flag it. Conversion numbers, audience counts, and channel attribution are all undercounting. Worth checking the tag loading order and any consent banner that might be blocking the request.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
High19 interactive elements have no stable, accessible identityBothAccessibility (WCAG)Tracking
These elements are clicked like buttons but expose no accessible name, or are a plain div/span used as a control with no role. Assistive tech announces only a role (or nothing), and analytics and heatmaps have no human-readable label or stable selector to bind the click to, so the click is both inaccessible and untrackable, and any redesign silently breaks click aggregation. Give each one a real <button>/<a>, an aria-label, and a stable id or data-attribute.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
HighSome text is low-contrast and hard to readBothAccessibility (WCAG)
Text that does not stand out enough from its background is hard to read for many visitors, and fails accessibility guidelines Google checks.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
HighJavaScript errors were logged during loadBothConversionTracking
Errors in the console often mean a feature silently broke: a button that does nothing, analytics that did not fire, a form that will not submit.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
HighBroken internal linksBothSEOConversion
1 internal link target returned an error (404/410/5xx) or did not respond. Broken links waste crawl budget, frustrate visitors, and leak ranking signal. (Found across a sample of 8 pages from your sitemap, a partial crawl rather than your full site.)
The exact examples we found:
  • https://flexrocksrollovers.com/collections/t-shirts (404)
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
MediumPage is heavy and slow on mobile dataBothPerformance
Each visit downloads about 5.2 megabytes, roughly 2227 KB of images and 1864 KB of JavaScript across 273 separate downloads. On a fast connection that's fine. On a phone with patchy mobile data, that's several seconds of blank screen before the page is readable.
median across loadsMeasured as the middle value across several test loads. Lab numbers wobble, so we report the median.
Medium4 potential dead-click targetsBothConversionAccessibility (WCAG)Tracking
Elements styled like buttons but with no anchor, no <button> wrapper, no role="button", and no click attribute. Real visitors tap these expecting something to happen, then leave. Examples on this page: "Watch the latest Video" (div.hero__link), "Save $5" (div.grid-product__tag), "Sold Out" (div.grid-product__tag).
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
MediumClick activity may be invisible inside the Facebook in-app browserBothTracking
Patterns on this page (64 custom-element tags) tend to suppress click events inside Android Webview and iOS in-app browsers. Visitors arriving from Meta ads may register as zero-interaction sessions even when they're actively using the page. Add a server-side landing tracker (or the Harvv pixel) so you don't lose that audience entirely.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
MediumSocial share image is served over insecure HTTPBothSEO
The Open Graph image is an http:// URL. Facebook, iMessage, Discord, LinkedIn and others often refuse to render an insecure preview image, so shared links can appear with no image even though one is set. Serve it over https.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
LowNo structured data for rich search resultsBoth
The page has no schema.org markup. Adding the right type (Product, Article, Organization, FAQ) lets Google show rich results like star ratings and prices, which lift click-through for free.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
LowThe page loads from a lot of third-party servicesBoth
Around 28 separate outside domains load on this page (analytics, ads, chat widgets, fonts). Each one is a connection that can be slow, fail, or change behavior outside your control.
median across loadsMeasured as the middle value across several test loads. Lab numbers wobble, so we report the median.
LowNo visible contact details (email or phone)BothConversion
The page exposes no email or phone link. For higher-value or trust-sensitive purchases, a clear way to reach a human reduces hesitation. Add an email or phone link in the header or footer.
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.
LowNo Organization or WebSite schemaBothSEO
No site-wide Organization or WebSite structured data found on any crawled page. This is the schema that tells Google and AI engines who you are (name, logo, social profiles) for the knowledge panel and brand recognition in AI answers. (Found across a sample of 8 pages from your sitemap, a partial crawl rather than your full site.)
identical every loadCame up the same on every test load. This is a hard fact about the page, not a one-off.

Accessibility findings are automated checks against Web Content Accessibility Guidelines (WCAG) 2.1 and 2.2. They flag potential barriers and legal risk, not a certification or a determination of compliance with the ADA, Section 508, or EN 301 549. Automated testing catches only a subset of issues; a full conformance review needs manual and assistive-technology testing by a qualified reviewer.

From finding to fix
Want the fix, not just the finding?
Install Harvv and we turn each issue above into a ready-to-paste prompt for your AI coding assistant. Drop it into Cursor, Claude, or Copilot and the diagnosis becomes a concrete code change, written against this exact page.
Get the fix prompts

"How we know": identical every load = a deterministic fact (e.g. element sizes). median across loads = a noisy lab metric, reported as a median. real-user field data = Google CrUX, actual Chrome visitors.

Structural and AI-search checks crawl up to 8 pages from your sitemap (a sample, not your full site). "Broken" means a link returned 404, 410, or 5xx, or did not respond; access-controlled pages (401, 403) are not counted.

02Performance: phone, desktop, and real visitors

MetricMobileDesktopRead
TTFB (lab median)17 ms21 msLab
FCP (lab median)676 ms534 msLab
LCP (lab median)1.0s856 msGood
Page weight (median)5.2 MB4.7 MBWatch

Google Lighthouse (lab): Performance n/a mobile / 49 desktop, SEO 100, Accessibility 90, Best Practices 73.

Lab numbers are from a headless mobile browser on an unthrottled connection: treat them as a floor, not a typical experience. Add a Google API key to light up real-user field data (CrUX) and Lighthouse scores.

03Tiny buttons are hard to tap on mobile

31 of 63 tappable items on this page come in below 44×44 pixels, the size Apple and Google both recommend for reliable tapping on a phone. The same ones came up small on every one of the 4 test loads, so this is the page itself, not a fluke.

When customers can't tap what they expect to, they get frustrated and many of them leave. They don't file a bug. They don't try again. They just leave. A desktop dashboard can't see this because it's the difference between a thumb and a cursor.

The buttons measuring below the minimum on this scan:

  • a 1x1 "Skip to content"
  • button 39x30 (no visible label)
  • a 215x40 "Watch the latest Video"
  • a 206x30 "Off Road T-Shirts"
  • a 56x30 "Hats"
  • button 33x33 "Next"
  • a 90x38 "View all"
  • a 129x38 "Shop T-Shirts"

The fix is CSS-only on most sites: add padding around the icon (don't just change the icon size) so the actual tap area is at least 44×44 pixels. No redesign, no new assets.

04Technical SEO & structured data

CheckResult
TitleFlex, Rocks & Rollovers - Off Road Apparel and Gear (51 chars)
Meta description314 chars
H11 on page
CanonicalPresent
Structured data (JSON-LD)None
Open GraphTitle + image

05The fix checklist

Everything to fix, priority first, each tagged with the screen it affects and a rough effort. Work top to bottom.

  1. Tiny buttons are hard to tap on mobileMobileCSS only
  2. Google Analytics tracking brokenBothDev afternoon
  3. 19 interactive elements have no stable, accessible identityBothDev afternoon
  4. Some text is low-contrast and hard to readBothVaries
  5. JavaScript errors were logged during loadBothDev afternoon
  6. Broken internal linksBothVaries
  7. Page is heavy and slow on mobile dataBothSmall
  8. 4 potential dead-click targetsBothCSS only
  9. Click activity may be invisible inside the Facebook in-app browserBothVaries
  10. Social share image is served over insecure HTTPBothVaries
  11. No structured data for rich search resultsBothVaries
  12. The page loads from a lot of third-party servicesBothDev afternoon
  13. No visible contact details (email or phone)BothVaries
  14. No Organization or WebSite schemaBothVaries

Effort is a rough read from the outside: "CSS only" means no new assets or backend work, "1 line" means a single tag, "Dev afternoon" means a developer needs to touch tracking or scripts.

06What this report cannot tell you

Everything above is from the outside, looking at the page on a simulated phone and desktop. The questions that actually decide revenue need real visitors. Install the Harvv pixel (one script tag, 16 KB, zero personal data, no engineering project) and within about 72 hours you'd know which buttons real customers tapped and missed, how often Google Analytics is missing visits, and exactly where mobile shoppers stalled and left. This report shows you where to look. The pixel shows you how often it happens, and to whom.

What to do next
See this same depth on your real visitors, every day.

Drop the Harvv pixel on flexrocksrollovers.com and we turn this one-off scan into ongoing measured behavior: which taps miss, where sessions stall, and the real drop rates. Free to start, no card needed.

Add the pixel free

07How we did this, and what it can't prove

  • 4 mobile + 2 desktop loads of one URL from headless Chrome (iPhone viewport at 390px, desktop at 1366px), June 29, 2026. Enough loads to separate real defects from random noise, not a full-site crawl.
  • Lab numbers, not real-user numbers (no field data was available for this run). Real devices on real networks run slower.
  • Friction is inferred, not counted. We can prove a button is small. We can't, from the outside, count how often it causes a missed tap. That requires the pixel on a live page.

Prepared by Harvv. Last updated June 29, 2026.

Related teardowns

Dealmath
Behavioral teardown
Mwjsautomations
Behavioral teardown
Getscentcast
Behavioral teardown
Masterpoweruae
Behavioral teardown

See all site teardowns →