Bootstrapped Founder #38: Killing Features for Fun and Profit
Dear founder,If you add features to your product indiscriminately, you will end up with a gigantic bloated mess of software. One way to deal with this is to be very careful when deciding if new features should be added. Another rarely used approach is to remove unused and outdated features. Removing the cruft from your SaaS product is akin to pruning a hedge: you will end up with a more recognizable shape and a clearer vision of what your product is all about. How Customers React When You Remove Features Here’s the thing with change: there will always be people who hate it, with or without reason. While notorious complainers can be safely ignored, pay close attention to people who react negatively to product removal. Your target customers should be the ones that you delight with your product, and you never know how people use your product in weird ways until you break a workflow that you never expected to be possible. You want to remove a file upload button because everyone drags their files into the browser? There will be that one user who uses their keyboard only. Removing the feature makes the whole product unusable to them all of a sudden. Make sure never to remove accessibility features because you don’t see the need for them yourself. Impaired users rely on these things to be able to use your product. Build as much accessibility as possible into the product from the beginning. When to Remove a Feature In some way or another, every reason to remove a feature from your product boils down to feature creep. Here are a few examples, both with reasons why they should be removed and how they come to happen. Remove unused features. When customers stop using features, they either found a better solution to their problem or they have a different problem to solve. As a result, unused features clutter the user interface of your product, not providing any value to your users. At best, they are a visual nuisance; at worst, they produce unintended side-effects, confusing your customers by their presence. Your codebase will also show signs of bloat when unused features stick around for too long. We removed such a feature at FeedbackPanda. It was initially introduced to allow our customers to migrate and amend their data from one product version to another. As some of our customers were rather slow to adopt the new version, we left the interface component in for a long time and forgot about it. Half a year after the last customer finished migrating, we finally removed the feature. While doing that, we figured out that some of our customers had misused that feature to change their data in weird ways that we didn't understand before. Talk about a side-effect! Remove features that distract from product focus. Sometimes, you build things because you think your customers need them, but they turn out to be misaligned with your purpose of solving your customers' critical problem. Those features can make other features less effective or at least harder to find and use. This is the ultimate incarnation of feature creep. It's what will turn your product into a tangled mess if you don't regularly trim the fat. Remove features that make the product too complex. Very similar to features that distract your users are features that overwhelm them. Many products have seen their customers churn because they became hopelessly complicated to use. It all starts with the intent to provide more value, but it eventually turns into feature overload. Remove features that are expensive to maintain. This removal opportunity is often overlooked. Some things that are part of your product may, at some point, cause performance issues or incur higher monetary costs than you're willing to pay. Often, it's easy to engineer and maintain heavy-duty features at the beginning of a business with only a few customers. Examples of this would be heavy background-processing of customer data, complicated imports, or extensive export scenarios. While limiting access to this feature may work, removing it is also an option if it's do-or-die. Why Does Feature Creep Happen? Feature creep happens for many reasons, and all come from a genuine belief that, at the moment when you conceptualize and build the feature, it's useful and providing value to your business and your customers. But, of course, just because you believe so doesn't make it real. I have built many features that I felt to be absolutely necessary only to shamefully admit defeat and remove them a few months after launching them. Here are a few situations where I should not have added a feature but did anyway: I just wanted to build it. Sometimes, you're only interested in understanding how things work, and you think you need to build it. I did so with the FeedbackPanda invoicing system. What started as a simple part of the application, not much more than a list, ended up being a PDF-generating monster and tax-calculating monster of a feature. In retrospect, that's a rabbit hole I should have never even looked at from a distance. I just wanted to get and convert a big customer. In a prior startup, I built several features for a prospective customer who promised to sign up if only those features were implemented. Of course, they never signed up even when I had deployed the changes, but we kept the feature in the application because we hoped that other customers could benefit from it somehow. They never did. I thought it was the one feature I needed to release for things to start happening. This is an example of the classical "Next Feature Fallacy": the thinking that the next thing you do will have the big impact you're waiting for. But it usually doesn't. Usually, it will be yet another attempt at making a big difference and failing. This is a great opportunity to dust yourself off and try again. Just make sure you remove the feature that has proven not to work. Don't keep it hanging around. There are a number of other reasons that can cause you to build things you shouldn't have: • "Premature Optimization"-like integrations. You thought you could use this eventually, and you'd better already have it in the product before you need it. Maybe you intend to eventually partner with a service, so you build an integration ahead of time. And then the partnership falls through, and you never need it. Many technical founders then fall prone to the sunk cost fallacy, thinking that since they already invested their time, the functionality needs to stay there. • You're trying to capitalize on trends. Ever implemented social-media-like functionality even if your customers never interact? I built a Facebook-like social stream with messages and comments for farmers who never took the time to use it because they were too busy harvesting their vegetables. But social media feeds were everywhere, so we just had to have something like this, too. It was not required at all, and completely unused, but we believed that we could pull it off. • You saw it somewhere else, and it looked rather cool. Founders get inspired by other software all the time, and then build something very similar in their own products. What they forget is that every feature exists within the context of a product. That cool overlay animation you see on a social network for designers will completely confuse your almost technically illiterate users. Try to avoid things that are not essential to your product. • You needed to release something, and it was quick to build. Sometimes, you feel like you just need to do something. You haven't released a new feature in weeks, and customers have always asked for something simple. It's not on your roadmap, and you didn't put it on there because it wasn't essential, but you know it will only take an hour or two. Now you have wasted your time twice. You didn't work on anything meaningful, and you will have to remove it again in the future. No matter what your reasons were then, you need a slim and efficient product now. So, trim the fat, and start removing those obsolete features. Removing a Feature the Empathetic Way If you want to remove a feature, sunset it. Make a public announcement about the removal close to when people who use the feature would read it. Then, turn it into an optional feature, using a configuration toggle. Change that toggle to default to an "off" state, and measure how many people react to it. Inform them how to re-enable it and how to work with your product without that feature. If you feel confident that removing the feature won't impact a significant amount of your target customers, remove it. Feature removal has multiple impacts: you can fully remove a feature, slowly wean customers off over a number of weeks, or phase out the feature via options until the last customer has stopped using it. No matter what speed you choose, the most important thing to remember is to communicate the changes to your users before and after you remove anything. This will reduce friction between you and your customers. It prepares them for an impending change and reduces the likelihood of them getting confused when it finally happens. By keeping your customers in the loop, you're reducing the customer service load you'll have when you remove the feature. Also, once they know about the change, they can look for alternative ways to solve their problem if they were users of the feature before. Use all the instruments at your disposal to communicate the removal to your customers. Tell them in-app and through an email. You never know where they are right now, and you need them to know both in advance through a thoughtful email and right when they are in the product, best in the location where the feature used to be. Update your knowledge base and prepare a transitionary video that clearly shows how to solve the problem alternatively if ever needed. The more you invest in communicating a feature removal, the less work you'll have on the customer service front. There Will Be Consequences Sometimes, you will learn that some features are part of very hard-to-change workflows for some of your users. Removing the feature will cause you to lose the customer in these cases. Sometimes, that is okay if the removal reduces complexity for everyone else. It's a balancing act. Be clear in your messaging, and insist on making the product a distinctive, slim, focused version of itself instead of succumbing to featuritis. If people ask why you removed a feature they used before, give them good reasons. Customers will understand when you say, "less is more, and this is making the product better." For your customers, the overall usefulness of your product will trump individual features when they have a chance to think about it. They may complain, but unless they cancel their subscription, they will see it as a viable move. Finally, by talking to customers before you remove a feature, you spread out the haters. The complainers will complain over a few days, sometimes to you, sometimes on social media, but their cries and yells will be sparse and manageable. Much better than when all hell breaks loose at the same time when you remove a feature without telling anyone. All in all, slimming down your product can have a net positive effect on the business, your customers, and the value they receive. Keep this tool handy when you're doing some business introspection. Not all questions have to be answered with a "What if we build this?"—some deserve a "We don't really need this!" You can find this article on the blog. I also recorded a podcast episode where I talk more about my experiences with feature creep, removing features, and what not to build. I wrote about building my own invoicing system earlier. That was a pretty stupid move, but at least I didn't build my own accouonting system. Mostly, because I didn't even know how that would work. This week, I came across
I found a number of very curious and insightful links this week that are not related to bootstrapping, but are incredible nonetheless: from Bootstrapping Success Stories
If you want to help me share my thoughts and ideas with the world, please share this episode of the newsletter on Twitter or wherever you like, or reach out on Twitter at See you next week! Warm Regards from Berlin,
|
Older messages
Bootstrapped Founder #37: Make It Stick
Friday, July 24, 2020
The Bootstrapped Founder Logo Dear founder, It won't take long before customers start asking for one particular kind of feature: integrating into other tools that they use all the time. They
Bootstrapped Founder #36: A Sellable Business Has SOPs
Friday, July 17, 2020
The Bootstrapped Founder Logo Dear founder, A quick update on my newly launched book Zero to Sold: within two weeks of being available on Amazon and Gumroad, I have sold over 1200 copies. Thank
Bootstrapped Founder #35: Roadmaps
Friday, July 10, 2020
The Bootstrapped Founder Logo Dear founder, This newsletter has no sponsors. I want to keep it that way. If you would like to support me, please consider purchasing a copy of my book Zero to Sold
Bootstrapped Founder #34: Customer Retention (also, I Launched a Book)
Friday, July 3, 2020
The Bootstrapped Founder Logo Dear founder, It has been an extraordinary week for me. After working on it for six months, I have released my book, Zero to Sold. It's been a whirlwind of a
Bootstrapped Founder #33: Seeing Through Your Customer’s Eyes
Friday, June 26, 2020
The Bootstrapped Founder Logo Dear founder, Once you reach the Stability Stage of your business, you have a mostly mature product that is used by many customers. You can expect that for most of
You Might Also Like
How much do founders earn?
Monday, January 13, 2025
+ UK government's AI plan; EU regulations to watch out for 2025 View in browser Leonard_Flagship Good morning there, If you didn't know much about startups, you might think all founders begin
🏙️ Building the Future: Parker Conrad's Journey
Sunday, January 12, 2025
A founder of two unicorns, Parker has had one of the more dramatic startup journeys in recent years. This Week at YC January 12th, 2025 ✨ The Latest How To Build The Future: Parker Conrad Parker Conrad
🚨 [LIVE IN 1 HOUR] Day 1 of the Challenge with Anthony Lazarus
Sunday, January 12, 2025
Get ready. Your journey to your first Shopify sale starts in just 1 hour. Hi Friend , The wait is almost over! Day 1 of the Make Your First Shopify Sale 5-Day Challenge starts in just ONE HOUR. ⌛
#214 | Startup themes for 2025, Palantir for Health, & more
Sunday, January 12, 2025
Jan 12th | The latest from Cowboy, Bowery, Matrix, Khosla, Homebrew, Maveron, and others ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
This weekend side project makes $16K/month
Sunday, January 12, 2025
Starter Story Sunday Breakfast ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
How to build your product team from scratch, attract top product talent, go multi-product, and more | Rohini Pandh…
Sunday, January 12, 2025
Rohini Pandhi on building beautiful products in "boring" industries ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
🔴 [Last call] 24 hours left to join the biggest ecomm challenge ever
Saturday, January 11, 2025
Don't miss your opportunity to finally launch your dream ecommerce business. Hi Friend , This is it—less than 24 hours left to join the Make Your First Shopify Sale 5-Day Challenge! If you've
💼 $16K/m with a ChatGPT wrapper
Saturday, January 11, 2025
Simple Job Interview Assistant
What’s 🔥 in Enterprise IT/VC #428
Saturday, January 11, 2025
The truth about building in AI according to Sam Altman - "there is no one at all who can tell you exactly how it should be done" ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏ ͏
My 2024 year in review
Saturday, January 11, 2025
Howdy! Happy New Year! Today, I'm finally sending you my annual review. (A little later than I'd hoped!) For over a decade now (eleven years!), I've been writing these annual reviews.