google.com
Ads are visible in the search results page but only in private browsing mode of Firefox for Android. No such issue in the regular (non-private) mode.
In the screenshot below, left hand column shows regular mode and right hand column shows private browsing mode of Firefox for Android.

Default
Google is serving different layouts in regular and private browsing mode of Firefox/Android. Changing the user agent to Chrome/Android fetches another different but uniform layout in both modes where the ads remain blocked.
private browsing mode is buggy, see https://bugzilla.mozilla.org/show_bug.cgi?id=1313401
Nothing to do with private browsing. You see two different pages. Google served old page to Firefox on Android for long time. Now Firefox is sending different user agent to Google search page to get new Chrome-like ("bubbles") interface and wee don't have cosmetic filters for this new interface yet.
Go to uBO Settings -> Filter lists, and remove selection from "Ignore generic cosmetic filters" checkbox. Edit: helped at first, but not for long.
uBO on Android ignores Generic cosmetic filters for performance reasons, and because of this generic cosmetic filters for Google are made specific and moved to "uBlock filters" manually - these filters must be updated.
I cannot "pick" good filter on Android - nth of type + random classes only :(
@uBlock-user I believe @gwarser is on the right track. My limited research tells me that Google notoriously serves inferior user experience on Firefox for Android. Recently there's been some change where either Firefox is spoofing new user agent in private browsing mode to bypass Google's game or perhaps Google is rolling out new layout or both IDK.
@gwarser Enabling or disabling "Ignore generic cosmetic filters" option doesn't seem to make any noticeable difference in my case, ads remain unblocked regardless of this setting. As of now, my only resolution is to keep Chrome/Android as UA for Google. Hoping for new ad filters to come up and be incorporated in uBO soon!
Advert:
<div data-hveid="CAwQAA"><div class="O9g5cc uUPGi ZINbbc xpd"><div><a class="C8nzq BmP5tf" href="http://www.google.com/aclk?sa=l&ai=DChcSEwiu-pbCndLdAhXhsO0KHSjiBP8YABAAGgJkZw&sig=AOD64_2dG7qvBvMfxpArHT4gaJRUEwRwuA&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQ0Qx6BAgMEAE&adurl=" data-al="1"><div aria-level="3" role="heading" class="MUxGbd v0nnCb">WebData Control | Improve User Experience | avanite.com</div><div class="zbELhe MUxGbd lyLwlc aLF0Z"><span class="rtDDKc VqFMTc">Reklama</span><span class="qzEoUe">www.avanite.com/</span></div></a></div><hr class="BUybKe"><div class="BmP5tf"><div class="MUxGbd">Remove Known Tracking And Advertising Cookies. Request A Demo! Reduce Webcache Bloat. FREE 14 Day Trial. Remove Advert Cookies. Tracking Cookie Removal.</div></div><hr class="BUybKe"><div class="Lgnr0e BmP5tf"><div class="MUxGbd v0nnCb lyLwlc"><a class="M6fFe" href="http://www.google.com/aclk?sa=l&ai=DChcSEwiu-pbCndLdAhXhsO0KHSjiBP8YABABGgJkZw&sig=AOD64_1z9Q4COfmcz2TinIlOVS9q3Ve2lA&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQwgUoAHoECAwQAw&adurl=" data-al="1">Download WebData Control</a></div><div class="MUxGbd v0nnCb lyLwlc"><a class="M6fFe" href="http://www.google.com/aclk?sa=l&ai=DChcSEwiu-pbCndLdAhXhsO0KHSjiBP8YABACGgJkZw&sig=AOD64_1sG3b8rcirGb2aJPbYsNeySyBaMg&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQwgUoAXoECAwQBA&adurl=" data-al="1">Analyse Your Environment</a></div></div></div></div>


Normal link:
<div class="O9g5cc uUPGi ZINbbc waTp2e xpd"><div><div><div class="jfp3ef"><a href="/url?q=https://pl.m.wikipedia.org/wiki/HTTP_cookie&sa=U&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQFjAAegQIBRAC&usg=AOvVaw1DFfj-jY6S7hVjsVd9J9lk"><div class="BNeawe vvjwJb AP7Wnd">HTTP cookie – Wikipedia, wolna encyklopedia</div><div class="BNeawe UPmit AP7Wnd">https://pl.m.wikipedia.org › wiki › HTTP...</div></a></div><div class="NJM3tb"></div><div class="jfp3ef"><a href="/url?q=https://pl.m.wikipedia.org/wiki/HTTP_cookie&sa=U&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQqa4BMAB6BAgFEAM&usg=AOvVaw1_8jZI2natf78XQ_IPfixy"><div class="yTEhUb SXn0g GXKcHe"><div style="width:90px;height:90px"><img class="EYOsld" alt="cookies z pl.m.wikipedia.org" src="" style="width:90px;height:90px" id="dimg_7" data-deferred="1" onload="typeof google==='object'&&google.aft&&google.aft(this)" data-iml="1537743655847"></div></div></a><div><div class="BNeawe s3v9rd AP7Wnd"><div><div><div class="BNeawe s3v9rd AP7Wnd">HTTP Cookie (tłumaczone czasem jako plik cookie, w skrócie cookie, również ciasteczko) – mały fragment tekstu, który ...
<span class="BNeawe"><a href="/url?q=https://pl.m.wikipedia.org/wiki/HTTP_cookie%23Zastosowanie&sa=U&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQ0gIwAHoECAUQBA&usg=AOvVaw1U3gZ32ItJga6EGfn2rWw5"><span class="XLloXe AP7Wnd">Zastosowanie</span></a></span> · <span class="BNeawe"><a href="/url?q=https://pl.m.wikipedia.org/wiki/HTTP_cookie%23Spos%25C3%25B3b_dzia%25C5%2582ania&sa=U&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQ0gIwAHoECAUQBQ&usg=AOvVaw04mfDdQFOuTre-zZOwrXWI"><span class="XLloXe AP7Wnd">Sposób działania</span></a></span> · <span class="BNeawe"><a href="/url?q=https://pl.m.wikipedia.org/wiki/HTTP_cookie%23Alternatywy_dla_cookie&sa=U&ved=2ahUKEwjNoZHCndLdAhUC-6QKHRqyBwMQ0gIwAHoECAUQBg&usg=AOvVaw3EHKFfoucWsFLShrf_RH_U"><span class="XLloXe AP7Wnd">Alternatywy dla cookie</span></a></span></div></div></div></div></div><div class="Uk2dG"></div></div></div></div></div>


google.*##div[data-hveid]?

@gwarser google.*##div[data-hveid] filter seems to work fine and the ads indeed disappear. But I just found that all the search results also disappear when the user agent is set to Chrome. I don't know if this is just specific to UA spoofing on Firefox/Android or if this is the case with Chrome/Android browser too.
I presume many users would have set their UA for Google as Chrome to receive their tier 1 content. This filter might be a bummer for them.
Using Chrome and adding
google.*##div[data-hveid]

I just checked and UA is not spoofed on Firefox Android. On my phone I see Mozilla/5.0 (Android 7.1.2; Mobile; rv:63.0) Gecko/63.0 Firefox/63.0 When I copy this exact UA to "Custom Device" in Firefox Responsive Design Mode, then I see exact same source on desktop browser. (DPR 1.5, and 480x800 screen - ancient phone :] )
How about:
!#if env_mobile
google.*##div[data-hveid]
!#endif
Works setting the UA to android using Chrome on my end.
I do not have a device running android, so somebody who does is better equipped to test and add a fix.
Same result with the updated filter. It works for Firefox/Android but switching the UA to Chrome/Android, Safari/iPhone or Safari/iPad, hides all the search results.
@krystian3w I tested both your filters separately. First one has the same problem that @gwarser's filter had - it works in Firefox/Android but hides all search results in many other cases like Chrome/Android, Safari/iPhone, etc. The second filter was working fine until I noticed an ad sneaking past due to its data-hveid starting from "CB" instead of "CA".
In all ads, one constant seems to be a span element with the text "Ad". I am not sure but maybe some filter targeting data-hveid containing this particular span element might just do the trick?
Okay guys, I did a little investigation by spoofing the user agent and here's what I found...
Following is the Tier 1 layout (received by mobile Chrome, Safari, etc.):
All the search results, including ads, are a few levels deep within the highlighted div and each of them has div[data-hveid].
Following is the Tier 2 layout (received by mobile Firefox):
All the search results, including ads, are children of div[id="main"]. But only the ads have div[data-hveid] and not the search results.
Based on this, I tested a filter google.*###main > div[data-hveid] which seems to do the job without any unintentional adverse effect (so far), i.e. ads get blocked in Firefox and rest of the browsers remain unaffected. I haven't actually tested it in real browsers other than Firefox (just UA spoofing) so others should please test and confirm.
Now, would all this info be of any help in creating an efficient filter?
@krystian3w I see no ads and only regular search results using those old version UA. The filter doesn't seem to negatively affect anything there. Do you get any problems with this new rule on either the mobile or desktop platform?
Ah, alright @krystian3w. Let's see if this filter works for others too without causing any trouble. No problems highlighted by anyone so far, maybe this issue will be closed soon.
Given that nothing else seems to be happening on this issue I am considering adding
!#if env_firefox
!#if env_mobile
google.*###main > div[data-hveid]
!#endif
!#endif
Does anyone have problems with this?
Has the issue been fixed by the commit?
I think so, I was leaving it open for someone to confirm.
Well, nobody is coming forward with any problem with this filter. I guess you guys should close the issue and re-open it later if someone does highlight a problem.
Does the filter google.*###main > div[data-hveid]:if-not(span.spell_orig) work for you? I do not have an android phone, so I cannot test it myself.
@krystian3w @ZaphodBeebblebrox The links in that div start from /search. May be the filter needs to be modified to exclude such divs.
Edit: Does google.*###main > div[data-hveid]:if-not(a[href^="/search"]) work?
@krystian3w Yes, do let us know if google.*###main > div[data-hveid]:if-not(a[href^="/search"]) works for you without causing any other trouble.
@ZaphodBeebblebrox The old filter is inadvertently hiding typo-related suggestions. Can you please re-open this issue until a new acceptable solution is found?
Both looks good, both hide this:

@krystian3w @gwarser I noticed not only typo-related suggestions but "Top stories", "Popular on Twitter", etc. sections are also getting hidden. Meanwhile the ads seem to have their link href along the lines of <google domain>/aclk?... while also having a new attribute data-al. So, I guess our ad blocking approach needs to be changed so as to not hide genuine content.
I tried the following two filters separately:
google.*###main > div[data-hveid]:has(a[href*="/aclk?"])
google.*###main > div[data-hveid]:has(a[data-al])
Both seem to just block ads without affecting anything else. Can you guys test whether an ad gets through and/or some genuine content gets hidden with any of these filters?
Just let me know what works, and I will add it. I don't have an android phone, so I can't test myself.
I don't have an android phone, so I can't test myself.
Do you really need one? https://www.digitalcitizen.life/emulate-mobile-device-desktop-browser
Ok, I was able to test with a combination of responsive design mode and a user agent spoofer. Does google.*##:xpath(//span[text()="Ad"]//..//..//..//..) cause any problems for you?
@ZaphodBeebblebrox Unfortunately, that filter would not work on non-English languages. What is your feedback on the two filters I listed earlier?
@krystian3w Try searching for "iPhone". It shows "Top stories" section in the search results. On one occasion, I also found "Popular on Twitter" feeds section on the same search results page but could not reproduce it (seems random).
And one would have to give one condition (mobile environment or Firefox environment, not together) for the time of repairing many servings as if gorhill added support multiple conditions.
AFAIK this particular layout is not served on any other platform. So, mobile/Firefox conditions are not really necessary. They were applied in the old filter but not actually required. Here too they can be applied but I think it's redundant, unless of course I am missing something.
google.*###main > div[data-hveid]:has(a[data-al]) appears to work for me as well. Let us know if you have any problems with it.
Hey guys, two issues:
Easylist has this div#main > div.ZINbbc.xpd.O9g5cc.uUPGi rule for many Google domains which is breaking the search results page on Firefox for Android. Sections like typo-related suggestions, what people ask, etc. are also getting blocked due to this rule.
The conditional rule last added by @ZaphodBeebblebrox needs to be updated where google.*###main > div[data-hveid]:has(a[data-al]) should possibly be replaced by google.*###main > div.ZINbbc.xpd.O9g5cc.uUPGi:has(a[data-al]).
If Easylist's rule in [1] is badfiltered and the one in [2] above is implemented then I think there should not be any issues. Maybe others can highlight any potential breakages and/or come up with a better solution.
Does the filter in [1] breaks something on desktop ?
Why the change of [2] ?
@ryanbr
I have not experienced any breakage with [1] on desktop.
The change of [2] maybe required since I no longer see div[data-hveid] but only div.ZINbbc.xpd.O9g5cc.uUPGi. Perhaps Google modified their code.
Could you test on mobile:
!#if env_mobile
google.*#@#div#main > div.ZINbbc.xpd.O9g5cc.uUPGi
!#endif
No dice. Breakage is still there on Firefox for Android.
Did you test on a mobile device or only using a desktop simulator ?
Both.
Edit: Never mind. It worked. Turns out Adguard Mobile Ads list has a similar rule as that of Easylist. Will have to report to them as well.
Okay, after digging around a bit more I think google.*##a[href*="/aclk?"][data-al]:xpath(../..) could be a safe rule. It can be wrapped in a conditional mobile directive but it's not really required.
This combined with the Easylist exception rule by @mapx- suggested here should block just the ads without breaking anything.
It will also eliminate the need for two currently existing rules - this and [2] above.
check again with the last filters
I used :nth-ancestor(2) for :xpath(../..)
Works great! Ads blocked. Nothing broken. Now waiting for the Adguard team to fix their rule.
@mapx- You can remove the exception rule now that the concerned filter has been taken off Easylist.
I may have the same issue. On Firefox Android I see 2 ads without ublock and 1 with it on. (I see a flash of both then one dissappears after less than a second.)
I have unsuccessfully attempted to use the rules above but I may have applied them wrong - I don't understand which comments above are still current.


Hey @mapx-, perhaps you should modify this filter to replace :nth-ancestor with :upward as per the deprecation note in uBO's latest release.
Everyone's not updated to the latest stable release.
Oh, right. Didn't realize that!
Most helpful comment
Using Chrome and adding

google.*##div[data-hveid]