Edit in JSFiddle

/*--------------------------------------------------------------------------

  jq-idealforms 2.0

  * Author: Cedric Ruiz
  * License: GPLv2
  * Demo: http://elclanrs.github.com/jq-idealforms/

--------------------------------------------------------------------------*/

;(function ($) {

  'use strict';

/*--------------------------------------------------------------------------*/

  /**
   * @namespace A chest for various Utils
   */
  var Utils = {
    /**
     * Get width of widest element in the collection.
     * @memberOf Utils
     * @param {jQuery object} $elms
     * @returns {number}
     */
    getMaxWidth: function ($elms) {
      var maxWidth = 0
      $elms.each(function () {
        if ($(this).outerWidth() > maxWidth) {
          maxWidth = $(this).outerWidth()
        }
      })
      return maxWidth
    },
    /**
     * Hacky way of getting LESS variables
     * @memberOf Utils
     * @param {string} name The name of the LESS class.
     * @param {string} prop The css property where the data is stored.
     * @returns {number, string}
     */
    getLessVar: function (name, prop) {
      var value = $('<p class="' + name + '"></p>').hide().appendTo('body').css(prop)
      $('.' + name).remove()
      return (/^\d+/).test(value) ? parseInt(value, 10) : value
    }
  }

/*--------------------------------------------------------------------------*/

  /**
   * @namespace Contains LESS data
   */
  var LessVars = {
    fieldWidth: Utils.getLessVar('ideal-field-width', 'width')
  }

/*--------------------------------------------------------------------------*/

  /**
   * A custom <select> menu jQuery plugin
   * @example `$('select').toCustomSelect()`
   */
  $.fn.toCustomSelect = function () {

    return this.each(function () {
      var $select = $(this)

      /**
       * Markup and elements of custom select
       * @memberOf $.fn.toCustomSelect
       * @returns {object} All elements of the new select replacement
       */
      var Select = (function () {
        var $options = $select.find('option'),
            $newSelect = $('<ul class="ideal-select"/>'),
            $menu = $('<li><span class="title">' + $options.filter(':selected').text() + '</span></li>'),
            items = (function () {
              var items = []
              $options.each(function () {
                var $this = $(this)
                items.push('<li><span class="item" ideal-value="' + $this.val() + '">' + $this.text() + '</span></li>')
              })
              return items
            }())

        $menu.append('<ul class="sub">' + items.join('') + '</ul>')
        $newSelect.append($menu)

        return {
          options: $options,
          select: $newSelect,
          title: $menu.find('.title'),
          sub: $menu.find('.sub'),
          items: $menu.find('.sub li')
        }
      }())

      /**
       * @namespace Methods of custom select
       * @memberOf $.fn.toCustomSelect
       */
      var Actions = {
        /**
         * @private
         */
        init: (function () {
          $select.css({
            position: 'absolute',
            left: '-9999px'
          })
          Select.select.insertAfter($select)
          Select.sub.hide()
          Select.items.eq(Select.options.filter(':selected').index()).find('span').addClass('selected')
        }()),
        noWindowScroll: function (e) {
          if (e.which === 40 || e.which === 38 || e.which === 13) {
            e.preventDefault()
          }
        },
        // Fix loosing focus when scrolling
        // and selecting item with keyboard
        focusHack: function () {
          setTimeout(function () {
            $select.trigger('focus')
          }, 1)
        },
        focus: function () {
          Select.select.addClass('focus')
          $(document).on('keydown.noscroll', Actions.noWindowScroll)
        },
        blur: function () {
          Select.select.removeClass('open focus')
          $(document).off('.noscroll')
        },
        scrollIntoView: function (dir) {
          var $selected = Select.items.find('.selected').parent(),
              itemHeight = $selected.outerHeight(),
              menuHeight = Select.sub.outerHeight(),
              isInView = (function () {
                var elPos = $selected.position().top + itemHeight
                return dir === 'down' 
                  ? elPos <= menuHeight 
                  : elPos > 0
              }())

          if (!isInView) {
            itemHeight = (dir === 'down') 
              ? itemHeight 
              : -itemHeight
            Select.sub.scrollTop(Select.sub.scrollTop() + itemHeight)
          }
        },
        scrollToItem: function () {
          var idx = Select.items.find('.selected').parent().index(),
              height = Select.items.outerHeight(),
              items = Select.items.length,
              allHeight = height * items,
              curHeight = height * (items - idx)

          Select.sub.scrollTop(allHeight - curHeight)
        },
        showMenu: function () {
          Select.sub.show()
          Select.select.addClass('open')
          Actions.select(Select.options.filter(':selected').index())
          Actions.scrollToItem()
        },
        hideMenu: function () {
          Select.sub.hide()
          Select.select.removeClass('open')
        },
        select: function (idx) {
          Select.items.find('span').removeClass('selected')
          Select.items.eq(idx).find('span').addClass('selected')
        },
        change: function (idx) {
          var text = Select.items.eq(idx).text()
          Actions.select(idx)
          Select.title.text(text)
          Select.options.eq(idx).prop('selected', true)
          $select.trigger('change')
        },
        keydown: function (key) {
          var idx = Select.items.find('.selected').parent().index()
          /**
           * @namespace Key pressed
           */
          var keys = {
            9: function () { // TAB
              if (Select.select.is('.menu')) {
                Actions.blur()
                Actions.hideMenu()
              }
            },
            13: function () { // ENTER
              if (Select.select.is('.menu')) {
                Select.select.is('.open')
                  ? Actions.hideMenu()
                  : Actions.showMenu()
              }
              Actions.change(idx)
            },
            27: function () { // ESC
              if (Select.select.is('.menu')) Actions.hideMenu()
            },
            40: function () { // DOWN
              if (idx < Select.options.length - 1) {
                Select.select.is('.open')
                  ? Actions.select(idx + 1)
                  : Actions.change(idx + 1)
              }
              Actions.scrollIntoView('down')
            },
            38: function () { // UP
              if (idx > 0) {
                Select.select.is('.open')
                  ? Actions.select(idx - 1)
                  : Actions.change(idx - 1)
              }
              Actions.scrollIntoView('up')
            },
            'default': function () { // Letter
              var letter = String.fromCharCode(key),
                  selIdx = Select.items.find('.selected').parent().index(),
                  curIdx = Select.items.filter(function () {
                    var re = new RegExp('^' + letter, 'i')
                    return re.test($(this).text())
                  }).first().index()

              Actions.change(!~curIdx ? selIdx : curIdx)
              Actions.scrollToItem()
              Actions.focusHack()
            }
          }
          keys[key] ? keys[key]() : keys['default']()
        }
      }

      /**
       * @namespace Holds all events of custom select for "menu mode" and "list mode"
       * @memberOf $.fn.toCustomSelect
       */
      var events = {
        focus: Actions.focus,
        'blur.menu': function () {
          Actions.blur()
          Actions.hideMenu()
        },
        'blur.list': function () {
          Actions.blur()
        },
        keydown: function (e) {
          Actions.keydown(e.which)
        },
        'clickItem.menu': function () {
          Actions.change($(this).index())
          Actions.hideMenu()
        },
        'clickItem.list': function () {
          Actions.change($(this).index())
        },
        'clickTitle.menu': function () {
          Actions.focus()
          Actions.showMenu()
          $select.trigger('focus')
        },
        'hideOutside.menu': function () {
          $select.off('blur.menu')
          $(document).on('mousedown.ideal', function (evt) {
            if (!$(evt.target).closest(Select.select).length) {
              $(document).off('mousedown.ideal')
              $select.on('blur.menu', events['blur.menu'])
            } else {
              Actions.focusHack()
            }
          })
        },
        'mousedown.list': function () {
          Actions.focusHack()
        }
      }

      // Bind events
      var disableEvents = function () {
        Select.select.removeClass('menu list')
        $select.off('.menu .list')
        Select.items.off('.menu .list')
        Select.select.off('.menu .list')
        Select.title.off('.menu .list')
      }

      // Menu
      Select.select.on('menu', function () {
        disableEvents()
        Select.select.addClass('menu')
        Actions.hideMenu()
        $select.on({
          'blur.menu': events['blur.menu'],
          'focus.menu': events.focus,
          'keydown.menu': events.keydown
        })
        Select.select.on('mousedown.menu', events['hideOutside.menu'])
        Select.items.on('click.menu', events['clickItem.menu'])
        Select.title.on('click.menu', events['clickTitle.menu'])
      })

      // List
      Select.select.on('list', function () {
        disableEvents()
        Select.select.addClass('list')
        Actions.showMenu()
        $select.on({
          'blur.list': events['blur.list'],
          'focus.list': events.focus,
          'keydown.list': events.keydown
        })
        Select.select.on('mousedown.list', events['mousedown.list'])
        Select.items.on('mousedown.list', events['clickItem.list'])
      })

      Select.select.on('menu') // Default to "menu mode"
    })
  }  

/*--------------------------------------------------------------------------*/

    /**
     * A custom <input type="radio|checkbox"> jQuery plugin
     * @example `$(':radio, :checkbox').toCustomRadioCheck()`
     */
    $.fn.toCustomRadioCheck = function () {
      return this.each(function () {
        var $this = $(this),
            $span = $('<span/>')

        $this.is(':checkbox') ? $span.addClass('ideal-check') : $span.addClass('ideal-radio')

        if ($this.is(':checked')) $span.addClass('checked')
        $span.insertAfter($this)

        $this
          .css({
            position: 'absolute',
            left: '-9999px'
          })
          .on({
            change: function () {
              var $this = $(this)
              $this.trigger('focus')
              if ($this.is(':radio')) {
                $this.parent().siblings('label').children('.ideal-radio').removeClass('checked')
                $this.next('.ideal-radio').addClass('checked')
              } else {
                $this.is(':checked')
                  ? $span.addClass('checked')
                  : $span.removeClass('checked')
              }
            },
            focus: function () {
              $span.parent().addClass('focus')
            },
            blur: function () {
              $span.parent().removeClass('focus')
            },
            click: function () {
              $(this).trigger('focus')
            }
          })
      })
    }

/*--------------------------------------------------------------------------*/

  /**
   * @namespace All default filters used for validation
   */
  var Filters = {
    number: {
      regex: /\d+/,
      error: 'Must be a number.'
    },
    digits: {
      regex: /^\d+$/,
      error: 'Must be only digits.'
    },
    name: {
      regex: /^[A-Za-z]{3,}$/,
      error: 'Must be at least 3 characters long, and must only contain letters.'
    },
    username: {
      regex: /^[a-z](?=[\w.]{3,31}$)\w*\.?\w*$/i,
      error: '名前の項目のエラーです。エラーメッセージはこのように表示されます。問題なければ別のメッセージが表示されます。'
    },
    pass: {
      regex: /(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,}/,
      error: 'パスワードの項目のエラーです。エラーメッセージはこのように表示されます。問題なければ別のメッセージが表示されます。'
    },
    strongpass: {
      regex: /(?=^.{8,}$)((?=.*\d)|(?=.*\W+))(?![.\n])(?=.*[A-Z])(?=.*[a-z]).*$/,
      error: 'パスワードが弱い場合のエラーメッセージです。問題なければ別のメッセージが表示されます。'
    },
    email: {
      regex: /^[\w\-\.\+]+\@[a-zA-Z0-9\.\-]+\.[a-zA-z0-9]{2,4}$/,
      error: 'メールアドレスのかき方が違うみたいです。'
    },
    phone: {
      regex: /^[2-9]\d{2}-\d{3}-\d{4}$/,
      error: '電話番号のかき方が違うみたいです。'
    },
    zip: {
      regex: /^\d{5}$|^\d{5}-\d{4}$/,
      error: '郵便番号が存在しないみたいです。みたいなエラーを出します。'
    },
    url: {
      regex: /^(?:(ftp|http|https):\/\/)?(?:[\w\-]+\.)+[a-z]{3,6}$/i,
      error: 'URLのエラー項目でエラーがあるみたいです。'
    },
    min: {
      regex: function (input, value) {
        var min = input.userOptions.data.min
        if (input.input.is(':checkbox, :radio')) {
          this.error = '最低でも<strong>' + min + '</strong>文字は使ってください'
          return input.input.filter(':checked').length >= min
        }
        this.error = '少なくとも<strong>' + min + '</strong>文字の長さでなければなりません。'
        return value.length > min - 1
      }
    },
    max: {
      regex: function (input, value) {
        var max = input.userOptions.data.max
        this.error = '最大で<strong>' + max + '</strong>文字までです。'
        return value.length <= max
      }
    },
    date: {
      regex: function (input, value) {
        var match = /^(\d{1,2})\/(\d{1,2})\/(\d{4})$/.exec(value),
            isDate = function (m, d, y) {
              return m > 0 && m < 13 && y > 0 && y < 32768 && d > 0 && d <= (new Date(y, m, 0)).getDate()
            }
        return match && isDate(match[1], match[2], match[3])
      },
      error: '誕生日は05/30/1979という形で入力します。</em>'
    },
    exclude: {
      regex: function (input, value) {
        this.error = '"' + value + '" は使用できません'
        return !~$.inArray(value, input.userOptions.data.exclude)
      }
    }
  }

/*--------------------------------------------------------------------------*/

  /**
   * @namespace jq-idealforms jQuery plugin
   */
  $.fn.idealforms = function (ops) {

      // Default options
      var o = $.extend({
        inputs: {},
        onSuccess: function (e) {
          alert('送信されました。(これはダミーです)')
        },
        onFail: function () {
          // What happens on submit if the form
          // does NOT validate.
          alert('入力ミスがアルっぽいです。入力内容を確認して下さい。')
        },
        filters: {
          // Add your own filters
          // ie. myfilter: { regex: /something/, error: 'My error' }
        },
        responsiveAt: 'auto',
        customInputs: true
      }, ops)

      // Merge custom and default filters
      $.extend(true, Filters, o.filters)

/*--------------------------------------------------------------------------*/

      var $form = this,
          /**
           * @namespace All form inputs of the given form
           * @memberOf $.fn.idealforms
           * @returns {object}
           */
          FormInputs = (function () {
            var $inputs = $form.find('input, select, textarea, :button'),
                $labels = $form.find('label:first-child'),
                $text = $inputs.filter(':text, :password, textarea'),
                $select = $inputs.filter('select'),
                $radiocheck = $inputs.filter(':checkbox, :radio'),
                $buttons = $inputs.filter(':button')

            return {
              inputs: $inputs,
              labels: $labels,
              text: $text,
              select: $select,
              radiocheck: $radiocheck,
              buttons: $buttons
            }
          }())

/*--------------------------------------------------------------------------*/

      /**
       * @namespace Methods of the form
       * @memberOf $.fn.idealforms
       */
      var Actions = {

        /** Create validation elements and neccesary markup
         * @private
         */
        init: (function () {

          var insertNewEls = function ($field) {
            var error = '<span class="error" />',
                valid = '<i class="icon valid-icon" />',
                invalid = $('<i/>', {
                  'class': 'icon invalid-icon',
                  click: function () {
                    var $this = $(this)
                    if ($this.siblings('label').length) { // radio & check
                      $this.siblings('label:first').find('input').focus()
                    } else {
                      $this.siblings('input, select, textarea').focus()
                    }
                  }
                })
            $(error).hide().insertAfter($field)
            $(valid).add(invalid).hide().appendTo($field)
          }

          $form.css('visibility', 'visible').addClass('ideal-form')
          $form.children('div').addClass('ideal-wrap')

          // Add novalidate tag if HTML5.
          FormInputs.inputs.attr('novalidate', 'novalidate')
          
          // Autocomplete causes some problems...
          FormInputs.inputs.attr('autocomplete', 'off')

          // Labels
          FormInputs.labels
            .addClass('ideal-label')
            .width(Utils.getMaxWidth(FormInputs.labels))

          // Text inputs & select
          FormInputs.text.add(FormInputs.select).each(function () {
            var $this = $(this)
            $this.wrapAll('<span class="ideal-field"/>')
            insertNewEls($this.parent())
          })

          // Radio & Checkbox
          FormInputs.radiocheck
            .parent()
            .filter(':last-child')
            .children()
            .each(function () {
              $(this).parent()
                .siblings('label:not(.ideal-label)').andSelf()
                .wrapAll('<span class="ideal-field ideal-radiocheck"/>')
            })
          insertNewEls(FormInputs.radiocheck.parents('.ideal-field'))

          // Custom inputs
          if (o.customInputs) {
            FormInputs.buttons.addClass('ideal-button')
            FormInputs.select.addClass('custom').toCustomSelect()
            FormInputs.radiocheck.addClass('custom').toCustomRadioCheck()
          }

          // Placeholder support
          if (!('placeholder' in $('<input/>')[0])) {
            FormInputs.text.each(function () {
              $(this).val($(this).attr('placeholder'))
            }).on({
              focus: function () {
                if (this.value === $(this).attr('placeholder')) $(this).val('')
              },
              blur: function () {
                $(this).val() || $(this).val($(this).attr('placeholder'))
              }
            })
          }
        }()),

        /** Validates an input
         * @memberOf Actions
         * @param {object} input Object that contains the jQuery input object [input.input]
         * and the user options of that input [input.userOptions]
         * @param {string} value The value of the given input
         * @returns {object} Returns [isValid] plus [error] if it fails
         */
        validate: function (input, value) {
          var isValid = true,
              error = '',
              userOptions = input.userOptions,
              userFilters

          if (userOptions.filters) {
            userFilters = userOptions.filters
            if (!value && /required/.test(userFilters)) {
              if (userOptions.errors && userOptions.errors.required) {
                error = userOptions.errors.required
              } else {
                error = 'ここは必須項目です。'
              }
              isValid = false
            }
            if (value) {
              userFilters = userFilters.split(/\s/)
              $.each(userFilters, function (i, uf) {
                var theFilter = Filters[uf]
                if (theFilter) {
                  if (
                    typeof theFilter.regex === 'function' && !theFilter.regex(input, value) ||
                    theFilter.regex instanceof RegExp && !theFilter.regex.test(value)
                  ) {
                    isValid = false
                    error = (userOptions.errors && userOptions.errors[uf]) || theFilter.error
                    return false
                  }
                }
              })
            }
          } else {
            isValid = true
          }
          return {
            isValid: isValid,
            error: error
          }
        },

        /** Shows or hides validation errors
         * @memberOf Actions
         * @param {object} input jQuery object
         * @param {string} evt The event on which `analyze()` is being called
         */
        analyze: function (input, evt) {

          var $input = FormInputs.inputs.filter('[name="' + input.attr('name') + '"]'),
              userOptions = o.inputs[input.attr('name')] || '',
              value = (function () {
                var iVal = input.val()
                if (iVal === input.attr('placeholder')) {
                  return
                }
                // IE8 and IE9 fix empty value bug
                if (input.is(':checkbox, :radio')) {
                  return userOptions && ' '
                }
                return iVal
              }())

          // Validate
          var test = Actions.validate({
            input: $input,
            userOptions: userOptions
          }, value)

          /**
           * @namespace Validation elements
           */
          var $field = input.parents('.ideal-field'),
              $error = $field.next('.error'),
              $invalid = (function () {
                if ($input.is(':checkbox, :radio')) {
                  return input.parent().siblings('.invalid-icon')
                }
                return input.siblings('.invalid-icon')
              }()),
              $valid = (function () {
                if ($input.is(':checkbox, :radio')) {
                  return input.parent().siblings('.valid-icon')
                }
                return input.siblings('.valid-icon')
              }())

          // Reset
          $field.removeClass('valid invalid')
          $error.add($invalid).add($valid).hide()

          // Validates
          if (value && test.isValid) {
            $error.add($invalid).hide()
            $field.addClass('valid')
            $valid.show()
          }
          // Does NOT validate
          if (!test.isValid) {
            $invalid.show()
            $field.addClass('invalid')
            // hide error on blur
            if (evt !== 'blur') $error.html(test.error).show()
          }
        },

        /** Deals with responsiveness aka adaptation
         * @memberOf Actions
         */
        responsive: function () {

          var maxWidth = LessVars.fieldWidth + FormInputs.labels.outerWidth()

          if (o.responsiveAt === 'auto') {
            $form.width() < maxWidth
              ? $form.addClass('stack')
              : $form.removeClass('stack')
          } else {
            $(window).width() < o.responsiveAt
              ? $form.addClass('stack')
              : $form.removeClass('stack')
          }

          // Labels
          var $emptyLabel = FormInputs.labels.filter(function () {
            return $(this).html() === '&nbsp;'
          })
          $form.is('.stack') ? $emptyLabel.hide() : $emptyLabel.show()

          // Custom select
          var $customSelect = FormInputs.select.next('.ideal-select')
          $form.is('.stack')
            ? $customSelect.trigger('list')
            : $customSelect.trigger('menu')
        }
      }

/*--------------------------------------------------------------------------*/

      /** Attach events to the form **/

      FormInputs.inputs
        .on('keyup change focus blur', function (e) {
          Actions.analyze($(this), e.type)
        })
        .blur() // Start fresh

      $form.submit(function (e) {
        if ($form.find('.ideal-field.invalid').length) {
          e.preventDefault()
          o.onFail()
        } else {
          o.onSuccess()
        }
      })

      // Responsive  
      if (o.responsiveAt) {
        $(window).resize(function () {
          Actions.responsive()
        })
        Actions.responsive()
      }

      return this

    }
}(jQuery))
          
          var $form = $('#my-form');

  $form.idealforms({
    inputs: {
      'username': {
        filters: 'required username exclude',
        data: {
          exclude: ['Paul', 'Mike']
        }
      },
      'pass': {
        filters: 'required pass',
      },
      'email': {
        filters: 'email'
      },
      'date': {
        filters: 'date'
      },
      'comments': {
        filters: 'min max',
        data: {
          min: 50,
          max: 200
        }
      },
      'states': {
        filters: 'exclude',
        data: {
          exclude: ['選択して下さい']
        },
        errors: {
          exclude: '選択して下さい'
        }
      },
      'langs[]': {
        filters: 'min',
        data: {
          min: 2
        },
        errors: {
          min: '<strong>2つ以上</strong>選択して下さい'
        }
      }
    }
  });
  
  $form.find('input:first').focus();    
  
body {
    background:url("");
    font: normal 15px/1.7 "Droid Sans", sans-serif;
    color: #222;
}
h1, h2, h3 {
    margin: 0;
    padding: 0;
    margin-bottom: .5em;
    line-height: 1;
}
h1 {
    font-size: 38px;
}
p {
    margin: .5em 0 1em 0;
}
ul {
    margin: 0;
    padding: 0 1em;
}
li {
    margin: .5em 0;
}
a:link,
a:visited {
    color: #2680BF;
    text-decoration: none;
    border-bottom: 1px solid #2680BF;
    font-weight: bold;
}

header {
    padding: 15px 0;
    margin-bottom: 60px;
    background: #285E85;
}
footer {
    padding: 40px 0;
    margin-top: 60px;
    background: #333;
    color: white;
    box-shadow: inset 1px 0 5px rgba(0,0,0,.85);
}
footer a:link,
footer a:visited {
    color: white;
    border-color: white;
}
#fork {
    float: right;
    margin: 0;
}
#copy {
    display: inline-block;
    margin: 0;
}
#title {
    color: white;
    font-size: 18px;
    display: inline-block;
    margin: 0;
    line-height: 34px;
}
#calltoaction {
    float: right;
    margin: 0 2em;
    line-height: 34px;
    color: white;
}
#download {
    float: right;
    background: white;
    padding: .3em 1.6em;
    color: #285E85;
    box-shadow: 0 0 5px rgba(0,0,0,.5);
    border-radius: 2px;
}
#download:active {
    position: relative;
    top: 1px;
    box-shadow: none;
}
.mycol {
    padding-top: 14px;
}
#my-form {
    border: 1px solid #ccc;
    padding: 3em;
    border-radius: 2px;
    box-shadow: 0 0 2px rgba(0,0,0,.2);
}
#comments {
    width: 350px;
    height: 100px;
}
  <div class="sevencol last">
    <form id="my-form">
      <div><label>名前:</label><input name="username" type="text"/></div>
      <div><label>パスワード:</label><input name="pass" type="password"/></div>
      <div><label>メール:</label><input name="email" type="text"/></div>
      <div><label>誕生日:</label><input name="date" type="text" placeholder="mm/dd/yy"/></div>
      <div>
        <label>言語:</label>
        <label><input type="checkbox" name="langs[]" value="japanese"/>日本語</label>
        <label><input type="checkbox" name="langs[]" value="English"/>英語</label>
        <label><input type="checkbox" name="langs[]" value="Chinese"/>中国語</label>
        <label><input type="checkbox" name="langs[]" value="Spanish"/>スペイン語</label>
        <label><input type="checkbox" name="langs[]" value="French"/>フランス語</label>
        <label><input type="checkbox" name="langs[]" value="German"/>ドイツ語</label>
        <label><input type="checkbox" name="langs[]" value="Korean"/>韓国語</label>
      </div>
      <div><label>ラジオボタン:</label>
        <label><input type="radio" name="radio"/>りんご</label>
        <label><input type="radio" name="radio"/>バナナ</label>
        <label><input type="radio" name="radio"/>ぶどう</label>
      </div>
      <div><label>都道府県:</label>
      <select name="states">
        <option value="選択して下さい">選択して下さい</option> 
        <option value="東京">東京</option> 
        <option value="福岡">福岡</option> 
        <option value="京都">京都</option> 
        <option value="大阪">大阪</option> 
        <option value="福島">福島</option> 
        <option value="広島">広島</option> 
        <option value="北海道">北海道</option> 
        <option value="山形">山形</option> 
        <option value="新潟">新潟</option> 
        <option value="京都">京都</option> 
        <option value="三重">三重</option> 
        <option value="富山">富山</option> 
      </select></div>
      <div><label>コメント:</label><textarea id="comments" name="comments"></textarea></div>
      <div><label>&nbsp;</label><button type="submit">送信</button></div>
      <div style="clear: both;"></div>
    </form>
  </div>