本文へスキップ
  1. Web BENTO CSS
  2. カテゴリ一覧
  3. フォーム部品
11 / FORM 12 パーツ

CSSフォームデザイン 12選

コピペで使えるおしゃれなCSSフォーム部品のサンプル集。トグルやチェックボックスは実際にクリックして動きを確認でき、シャッフルでアクセント色のバリエーションを試せます。見た目はJavaScript不要のCSSだけで完成します(文字数カウンターなど一部の動作にはJSを使います)。クラス名は .bnto-form-toggle 形式です。

該当するパーツが見つかりませんでした。

フォーカスグロー入力欄

.bnto-form-input {
  padding: 11px 14px; font-size: 14px;
  border: 2px solid #D8D0C2;
  border-radius: 12px;
  background: #fff; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.bnto-form-input:focus {
  border-color: hsl(258 47% 56%);
  box-shadow: 0 0 0 3px hsl(258 47% 56% / 0.22);
}
使い方のコツ

box-shadow: 0 0 0 3px はぼかしゼロの「縁取り」で、フォーカスリングの定番テクニック。outline: none で標準の枠を消すときは、必ずこのような代替の :focus スタイルをセットで付けてください。

下線インプット

.bnto-form-underline {
  padding: 10px 4px; font-size: 14px;
  border: none;
  border-bottom: 2px solid #D8D0C2;
  background: transparent; outline: none;
  transition: border-color .25s;
}
.bnto-form-underline:focus {
  border-bottom-color: hsl(5 100% 65%);
}
使い方のコツ

背景が透明なので、色付きセクションや写真の上でも馴染むのが下線型の強み。ただし入力欄だと気づかれにくいので、placeholderlabel を必ず添えてください。

フローティングラベル

.bnto-form-float { position: relative; display: inline-block; }
.bnto-form-float input {
  width: 100%; box-sizing: border-box;
  padding: 20px 14px 8px; font-size: 14px;
  border: 2px solid #D8D0C2; border-radius: 12px;
  outline: none; transition: border-color .2s;
}
.bnto-form-float span {
  position: absolute; left: 15px; top: 15px;
  font-size: 14px; color: #9a958c;
  pointer-events: none; transition: all .18s;
}
.bnto-form-float input:focus { border-color: hsl(327 60% 56%); }
.bnto-form-float input:focus + span,
.bnto-form-float input:not(:placeholder-shown) + span {
  top: 6px; font-size: 10.5px; font-weight: 700;
  color: hsl(327 60% 56%);
}
使い方のコツ

:placeholder-shown は「プレースホルダーが表示中=未入力」を判定する疑似クラス。placeholder=" " の半角スペースを消すと動かなくなるので注意。入力済みのままラベルが上に残るのはこの仕組みのおかげです。

検索ボックス

.bnto-form-search { position: relative; display: inline-block; }
.bnto-form-search input {
  width: 100%; box-sizing: border-box;
  padding: 11px 14px 11px 38px; font-size: 14px;
  border: 2px solid #D8D0C2;
  border-radius: 30px; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.bnto-form-search input:focus {
  border-color: hsl(202 73% 56%);
  box-shadow: 0 0 0 3px hsl(202 73% 56% / 0.22);
}
.bnto-form-search svg {
  position: absolute; left: 13px; top: 50%;
  transform: translateY(-50%);
  color: #9a958c; pointer-events: none;
}
使い方のコツ

アイコンには pointer-events: none を付けて、クリックが下の input に届くようにするのがポイント。左パディングの 38px はアイコン幅+余白なので、アイコンサイズを変えたら合わせて調整してください。

トグルスイッチ

.bnto-form-toggle { display: inline-flex; cursor: pointer; }
.bnto-form-toggle input { display: none; }
.bnto-form-toggle span {
  width: 50px; height: 28px; border-radius: 30px;
  background: #D8D0C2; position: relative; display: block;
  transition: background .25s;
}
.bnto-form-toggle span::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.2);
  transition: left .25s;
}
.bnto-form-toggle input:checked + span { background: hsl(119 31% 51%); }
.bnto-form-toggle input:checked + span::after { left: 25px; }
使い方のコツ

中身は普通のチェックボックス。input:checked + span で背景色を変え、つまみ(::after)を left で右へ動かしています。label で全体を囲んでいるので、つまみ以外をクリックしても切り替わり、JSは不要です。

チェックボックス

.bnto-form-check { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; }
.bnto-form-check input { display: none; }
.bnto-form-check span {
  width: 24px; height: 24px;
  border-radius: 7px;
  border: 2px solid #D8D0C2;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s;
}
.bnto-form-check span::after {
  content: "✓"; color: #fff; font-size: 14px;
  opacity: 0; transition: opacity .15s;
}
.bnto-form-check input:checked + span {
  background: hsl(5 100% 65%); border-color: hsl(5 100% 65%);
}
.bnto-form-check input:checked + span::after { opacity: 1; }
使い方のコツ

チェックマークは content: "✓" の文字で描いているので追加画像は不要。より綺麗にしたい場合は ::afterborder の L字回転やSVG背景に差し替えてもOKです。文字ごと label なのでテキスト部分をクリックしても反応します。

ラジオボタン

.bnto-form-radio { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; }
.bnto-form-radio input { display: none; }
.bnto-form-radio span {
  width: 24px; height: 24px; border-radius: 50%;
  border: 2px solid #D8D0C2;
  display: inline-flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s;
}
.bnto-form-radio span::after {
  content: ""; width: 10px; height: 10px; border-radius: 50%;
  background: #fff; transform: scale(0); transition: transform .15s;
}
.bnto-form-radio input:checked + span {
  background: hsl(202 73% 56%); border-color: hsl(202 73% 56%);
}
.bnto-form-radio input:checked + span::after { transform: scale(1); }
使い方のコツ

ラジオは name 属性が同じもの同士で「1つだけ選べる」グループになります。中央の丸は transform: scale(0→1) で表示しているので、ポンッと弾む切り替えになります。

セグメント切替

.bnto-form-pillswitch { display: inline-flex; cursor: pointer; }
.bnto-form-pillswitch input { display: none; }
.bnto-form-pillswitch span {
  display: inline-flex; border: 2px solid #D8D0C2;
  border-radius: 30px; overflow: hidden;
  font-weight: 800; font-size: 13px;
}
.bnto-form-pillswitch b {
  padding: 8px 18px; color: #9a958c;
  transition: background .2s, color .2s;
}
.bnto-form-pillswitch b:first-child { background: hsl(258 47% 56%); color: #fff; }
.bnto-form-pillswitch input:checked + span b:first-child { background: transparent; color: #9a958c; }
.bnto-form-pillswitch input:checked + span b:last-child { background: hsl(258 47% 56%); color: #fff; }
使い方のコツ

チェックボックスのON/OFFを左右の選択に見立てた2択専用のスイッチです。料金プランの「月額/年額」切替の定番UI。3択以上にしたい場合はラジオボタンをベースに作り替えてください。

セレクトボックス

.bnto-form-select {
  padding: 11px 38px 11px 14px; font-size: 14px;
  border: 2px solid #D8D0C2;
  border-radius: 12px;
  appearance: none; -webkit-appearance: none;
  cursor: pointer; outline: none;
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239a958c' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color .2s, box-shadow .2s;
}
.bnto-form-select:focus {
  border-color: hsl(327 60% 56%);
  box-shadow: 0 0 0 3px hsl(327 60% 56% / 0.22);
}
使い方のコツ

appearance: none でブラウザ標準の矢印を消し、background-image のSVGデータURIで自前の矢印を描いています。矢印の色を変えたいときはデータURI内の stroke='%239a958c'(=#9a958c)を書き換えてください。

レンジスライダー

.bnto-form-range {
  -webkit-appearance: none; appearance: none;
  height: 6px; border-radius: 6px;
  background: #D8D0C2; outline: none;
}
/* Chrome / Safari */
.bnto-form-range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 20px; height: 20px; border-radius: 50%;
  background: hsl(41 100% 50%); border: 3px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.25); cursor: pointer;
}
/* Firefox */
.bnto-form-range::-moz-range-thumb {
  width: 20px; height: 20px; border-radius: 50%;
  background: hsl(41 100% 50%); border: 3px solid #fff;
  box-shadow: 0 1px 4px rgba(0,0,0,.25); cursor: pointer;
}
使い方のコツ

つまみの装飾はベンダー疑似要素でしか効きません。Chrome/Safari用の ::-webkit-slider-thumb とFirefox用の ::-moz-range-thumb の両方に同じスタイルを書くのが安全です。先に appearance: none で標準の見た目を消すのを忘れずに。

テキストエリア

.bnto-form-textarea {
  min-height: 64px; padding: 11px 14px;
  border: 2px solid #D8D0C2;
  border-radius: 12px;
  font-size: 14px; font-family: inherit;
  resize: vertical; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.bnto-form-textarea:focus {
  border-color: hsl(119 31% 51%);
  box-shadow: 0 0 0 3px hsl(119 31% 51% / 0.22);
}
使い方のコツ

resize: vertical で「縦方向だけ」ユーザーがサイズ変更でき、レイアウト崩れを防げます。font-family: inherit を忘れるとテキストエリアだけ等幅フォントになりがちなので注意。

カウンタ付きテキストエリア

.bnto-form-count { position: relative; display: inline-block; }
.bnto-form-count textarea {
  width: 100%; box-sizing: border-box; min-height: 72px;
  padding: 11px 14px 26px; font-size: 14px;
  border: 2px solid #D8D0C2; border-radius: 12px;
  font-family: inherit; resize: none; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.bnto-form-count textarea:focus {
  border-color: hsl(258 47% 56%);
  box-shadow: 0 0 0 3px hsl(258 47% 56% / 0.22);
}
.bnto-form-count i {
  position: absolute; right: 12px; bottom: 10px;
  font-style: normal; font-size: 11px; font-weight: 700;
  color: #9a958c; pointer-events: none;
}
使い方のコツ

見た目はCSSだけで完成しますが、実際に数字を動かすにはJSが1行必要です。例:ta.addEventListener('input', () => counter.textContent = ta.value.length + ' / 140')。下部の余白(padding-bottom: 26px)がカウンタの居場所です。

CSSフォームデザインの基礎知識

入力フォームは、問い合わせ・会員登録・購入などの手前にあるコンバージョン直前の関門です。入力欄が押しづらい、今どこにフォーカスしているか分からない——そんな小さなストレスが離脱の原因になるため、フォームの使いやすさはデザインの中でも特に費用対効果の高い改善ポイントです。このページでは、コピペで使えるおしゃれなCSSフォーム部品を12種類掲載しています。

チェックボックスのカスタマイズやトグルスイッチは、ブラウザ標準の見た目のままでは装飾がほぼ効きません。定番の手法は2つ。selectinput type="range" には appearance: none で標準スタイルを消してから自前で描く方法、チェックボックスやラジオボタンには 本物の input を隠して隣の要素をCSSで描き、input:checked + span で状態を切り替える方法です。どちらもJavaScript不要で、このページのパーツはすべてプレビュー上で実際にクリックして動きを確かめられます。

フォーカス表示は消さない(アクセシビリティ)

outline: none でフォーカス枠を消しっぱなしにすると、キーボード操作のユーザーが現在地を見失います。消す場合は必ず :focusborder-color の変更や box-shadow のリングなど、代わりのフォーカス表示を用意してください。

タップしやすいサイズ(44px目安)

スマホでの操作を考えると、チェックボックスやトグルなどのタップ領域は44×44px前後が目安。見た目の図形が小さくても、label で文字ごと囲めばテキスト部分もクリック領域になり、実質的なタップ範囲を広げられます。

labelとinputの正しい紐付け

ラベルは <label> で input を包むか、for 属性と id で紐付けます。紐付いたラベルはクリックで入力欄にフォーカスが移り、スクリーンリーダーにも項目名が正しく伝わります。placeholder はラベルの代わりにはならない点に注意しましょう。

よくある質問

トグルスイッチやチェックボックスはJavaScriptなしで動きますか?
はい。本物の input type="checkbox" を隠して、隣の span を CSS で描く仕組みです。input:checked + span というセレクタで状態を切り替えるため、JavaScriptは一切不要でクリックすると動きます。
コピーしたコードはそのまま使えますか?
はい。CSSタブのコードをスタイルシートに、HTMLタブのコードをページに貼り付けるだけで動きます。トグルやチェックボックスはHTMLタブの input + label 構造が必須なので、必ずセットでコピーしてください。クラス名は bnto- で始まる独自プレフィックス付きです。
ブラウザ標準のフォームの見た目を消すには?
selectinput type="range" には appearance: none; を指定すると標準の見た目が消え、CSSで自由にデザインできます。チェックボックスやラジオボタンは input を非表示にして隣の要素を描く方法が定番です。
商用サイトで利用できますか?
はい、すべてのパーツは商用・個人を問わず無料で利用できます。登録やクレジット表記も不要です。
このページのパーツはAIコーディングツールでも使えますか?
はい。Claude CodeやCursorのようにWebページを読めるAIには、このページのURLとパーツ名(例:「下線インプット」)を伝えるだけで適用を指示できます。AIがWebを読めない場合は、「コピー」ボタンで取得したHTMLとCSSをチャットに貼り付けて調整を頼むのが確実です。改変後のコードは、公開前に表示確認することをおすすめします。

関連カテゴリ

フォームと組み合わせて使いやすいパーツはこちら。