Hardly any web developers had the deep skill set needed to pull it off.
I'm personally of the opinion it's not so much an issue of a lack of talent that prevented graceful fallback from being adopted, but simply the amount of extra effort necessary to implement it properly.
In my opinion, to do it properly you can't make any assumptions about the browser your app is running on; you should never base anything on the reported user agent string. Instead, you need to test for each individual JavaScript, HTML, (or sometimes even CSS) feature and design the experience around having a fallback for when that one singular piece of functionality isn't present. Otherwise you create a brand new problem where, for example, a forked Firefox browser with a custom user agent string doesn't get recognized despite having the feature set to provide the full experience, and that person then gets screwed over.
But yeah, that approach is incredibly cumbersome and time consuming to code and test for. Even with libraries that help with properly detecting the capabilities of the browser, you'll still need to implement granular fallbacks that work for your particular application, and that's a lot of extra work.
Add to that the fact devs in this field are already burdened with having to support layouts and designs that must scale responsively to everything ranging from a phone screen to a 100" inch TV and it quickly becomes nearly impossible to actually finish any project on a realistic timeline. Doing it that way is a monumental task to undertake, and realistically it probably mainly benefits people that use NoScript or similar -- so not a lot of people.