- バーティカルSaaS(業界特化SaaS)とホリゾンタルSaaSの違いと、今注目される理由
- FUNBREWが開発した造園業向けSaaS「niwakura」の開発背景・課題・選定プロセス
- モバイルファースト・ITリテラシーの低いユーザーへのUX設計の具体的な手法
- フリーミアム料金モデルと月額1,980円の価格根拠
- MVP設計からv1.16.6まで継続改善を支えた運営・フィードバックの仕組み
業界特化SaaS(バーティカルSaaS)とは
SaaSには大きく分けて2種類あります。あらゆる業種に対応する「ホリゾンタルSaaS(横断型)」と、特定の業界・職種に絞った「バーティカルSaaS(縦断型)」です。
Salesforce・Slack・NotionなどはホリゾンタルSaaSの代表例です。一方、バーティカルSaaSは医療・建設・農業・美容室など、ニッチな業界の固有課題を解決することに特化しています。
| 比較項目 | ホリゾンタルSaaS | バーティカルSaaS |
|---|---|---|
| 対象ユーザー | 業種横断 | 特定業界に限定 |
| 競合 | 多数・大手も多い | 少ない・ニッチ |
| 機能 | 汎用的 | 業界固有の業務に特化 |
| スイッチングコスト | 低め | 高い(業務に深く入り込む) |
| ARPUの傾向 | 低〜中 | 中〜高 |
バーティカルSaaSが近年注目される背景には、ホリゾンタル市場の飽和と、DX化が遅れる中小企業・職人業界へのデジタル需要があります。特に従業員10名以下の小規模事業者は、大手SaaSが想定しない独自の業務フローを持っており、そこに大きなビジネスチャンスが眠っています。
niwakuraの開発背景
FUNBREWが開発したniwakuraは、造園業・植木屋向けの見積・請求書作成SaaSです。「なぜ造園業なのか」と聞かれることがよくありますが、その答えは業界の構造的な課題にあります。
造園業界が抱えていた課題
- 手書き見積もり文化:現場で手書きした見積書をFAXで送るフローが今も主流
- IT活用の遅れ:50〜70代の職人が経営者の場合、スマートフォンの操作自体が障壁になる
- 見積精度のばらつき:植木の本数・樹種・作業時間を目視で計算するため、ミスや漏れが発生しやすい
- 請求管理の属人化:Excelや紙台帳での管理が多く、入金漏れや二重請求が起きやすい
汎用の見積ソフトでは「植木の樹種・本数・サイズ別単価」「枝打ち・消毒・剪定の工程別費用」といった造園業固有のマスタが存在しません。結果として「使いこなせない」と敬遠されてきました。
なぜこの業界を選んだか
業界のデジタル化余地が大きく、既存の競合プロダクトが少ないことが決め手でした。また、知り合いの造園業者にヒアリングしたところ、ペインが明確だったことが開発の決め手になりました。
市場調査・ニーズ検証
ターゲットの絞り込み
最初の検討では「造園業全般」を対象にしていましたが、調査を進めるうちにターゲットを従業員1〜5名の零細造園業者に絞りました。その理由は以下の通りです。
- 国内の造園業者の約7割が従業員5名以下の小規模事業者(業界統計より)
- 大規模事業者はすでに基幹システムを導入済みか、導入検討の判断プロセスが長い
- 零細事業者はオーナー1人が見積・施工・請求を兼任しており、工数削減ニーズが最も高い
ペインの特定方法
ターゲット設定後、以下の方法でペインを深掘りしました。
- ヒアリング:知り合いの造園業者にヒアリングを実施。見積作業の手間が大きな課題だと確認
- 現場同行:実際の剪定・造園作業に同行し、帰社後の見積作成フローを観察
- Googleキーワード調査:「造園 見積書 テンプレート」「植木屋 請求書 無料」などの検索ボリュームから潜在需要を確認
プロダクト設計のポイント
モバイルファースト設計
造園業の職人は現場(屋外)でスマートフォンを使って見積を作成します。PCでの作業を前提としたUIでは使ってもらえません。そのため、最初からスマートフォン画面(375px幅)を基準にUIを設計しました。
65歳の職人でも使えるUX
ITリテラシーが低いユーザーを想定したUX設計では、以下の原則を徹底しました。
- タップ対象は44px以上:誤タップを防ぐため、ボタン・リンクの最小サイズを厳守
- 文字サイズは16px以上:視認性を確保し、拡大操作を不要にする
- 操作ステップを最小化:見積作成から送付まで、最大3ステップで完了できるフローを設計
- エラーメッセージを平易な言葉で:「バリデーションエラー」ではなく「金額を入力してください」と表示
- ユーザーテスト必須:各機能リリース前に60代のユーザーに実際に操作してもらい、詰まるポイントを修正
最小機能セット(MVP)の定義
v1.0のリリース時点では以下の機能のみに絞りました。スコープを絞ることで、早期リリースを実現しました。
- 顧客管理(氏名・住所・連絡先)
- 見積書作成・PDF出力・メール送付
- 請求書作成・PDF出力・メール送付
- 造園業専用の作業項目マスタ(樹種・工程・単価)
技術選定と開発
採用技術スタック
niwakuraの技術構成はFUNBREWが得意とする以下のスタックです。
- バックエンド:Laravel(PHP)
- フロントエンド:Vue.js + Inertia.js
- アプリ形式:PWA(Progressive Web App)
- インフラ:AWS(EC2 + RDS + S3)
なぜネイティブアプリではなくPWAか
モバイルアプリとして提供する場合、ネイティブアプリ(iOS/Android)とPWAの2択があります。niwakuraがPWAを選んだ理由は明確です。
| 比較項目 | ネイティブアプリ | PWA |
|---|---|---|
| 開発コスト | 高い(iOS+Android×2倍) | 低い(Web1本で対応) |
| アップデート配信 | ストア審査が必要 | 即時反映 |
| インストール障壁 | App Store/Google Playが必要 | ブラウザからホーム追加 |
| オフライン対応 | 容易 | Service Workerで対応可 |
ターゲットユーザーの多くが「App Storeでアプリを探す」習慣を持っていないことも、PWA選択の後押しになりました。URLを送るだけでインストールできる手軽さは、ITリテラシーの低いユーザー層に適しています。
SaaS開発の全体的なプロセスについては SaaS開発ガイド|プロダクト設計からリリースまでの全工程 も合わせてご覧ください。
料金モデルの設計
フリーミアム戦略の採用
業界全体のITリテラシーが低い市場では、「まず無料で使ってもらう」ことがユーザー獲得の最短ルートです。niwakuraでは以下の料金体系を設計しました。
- フリープラン:月間見積書3件まで無料、PDFに「niwakuraで作成」のウォーターマーク付き
- スタンダードプラン:月額1,980円(税込)、見積・請求書の件数無制限、ウォーターマークなし
1,980円という価格の根拠
料金設定には以下の根拠があります。
- 競合調査:汎用の見積ソフトは月額3,000〜10,000円が相場。業界特化ツールとして高機能でも価格を抑えることで参入障壁を下げる
- WTP調査:インタビューで「月いくらまでなら払えるか」を確認。1,500〜2,500円のレンジが最多回答
- 心理的価格設定:2,000円を超えると「高い」と感じる層が増えるため、1,980円に設定
- ROI訴求:月1件の見積ミスをなくすだけで、1,980円の元が取れると説明できる
ローンチ後の運営・改善
ユーザーフィードバックの収集
リリース後は知り合いの造園業者に使ってもらいながら、フィードバックをもとに改善を重ねました。アプリ内のフィードバック機能やLINEを通じて、ユーザーの声を集めています。
v1.16.6まで継続した改善
ローンチ後、niwakuraはユーザーの声をもとに継続的なアップデートを重ね、v1.16.6まで機能拡張・品質改善を続けています。主な追加機能は以下の通りです。
- 写真添付機能(現場写真を見積書に貼り付け)
- 顧客へのSMS送付機能(メールを使わない層に対応)
- 入金確認機能(請求書の入金状況を一覧管理)
- テンプレート保存機能(よく使う作業項目セットを保存・呼び出し)
バーティカルSaaSの強みは、ユーザーと深い関係を築けることです。「要望を出したら次のバージョンで対応してもらえた」という体験がロイヤルティを高め、解約率の低下につながります。
まとめ:バーティカルSaaS開発で重要なこと
niwakuraの開発経験から導き出した、バーティカルSaaS開発の成功要因をまとめます。
- 業界選定が9割:競合の少ない、かつペインが明確な業界を選ぶことが最重要。デジタル化が遅れている業種ほどチャンスがある
- 徹底的なユーザー理解:ペルソナを「65歳の職人」まで具体化し、その人が使えるUXを設計する
- MVPを本当に最小化する:リリース後のフィードバックで機能を追加できる。最初から全機能を盛り込まない
- フリーミアムで導入障壁を下げる:ITに不慣れなユーザーには、まず無料で体験させることが最も効果的
- 継続的な改善を仕組み化する:フィードバックチャネルを複数設け、リリースサイクルを短く保つ
FUNBREWでは、業界特化SaaSの企画・開発・運用支援を行っています。自社業界のDXツールを開発したい事業者様は、ぜひお気軽にご相談ください。
この記事をシェア