@charset "utf-8";

/* ================================================================================
form
================================================================================= */


/* ================================================================================
form　共通パーツ
================================================================================= */
.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area input[type="number"],
.form_area button,
.form_area textarea {
  width:100%;
  margin:0;
  padding:6px 12px;
  background:#fff;
  border:1px solid #bbb;
  outline:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  box-sizing:border-box;
  vertical-align:bottom;
  font-size:1.4rem;
  border-radius:0;
}
.form_area input[type="checkbox"] {
  position:relative;
  top:-1px;
  vertical-align:middle;
}
.form_area textarea {
  min-height:160px;
}
.form_area input.small {
  max-width:200px;
}
.form_area input.mid {
  max-width:300px;
}

.bt_form {
  display:-webkit-flex;
  display:flex;
  -webkit-justify-content:center;
  justify-content:center;
  margin:35px 0;
  text-align:center;
}
.bt_form li + li {
  margin-left:35px;
}
.bt_form button {
  display:block;
  width:100%;
  border:none;
  padding:0;
  margin:0;
}
.bt_form span {
  display:inline-block;
  width:220px;
  padding:12px 15px;
  background:#000;
  border:none;
  color:#fff;
  font-size:1.8rem;
  font-weight:bold;
  cursor:pointer;
}
.bt_form a span:hover,
.bt_form button:hover {
  opacity:.7;
}
.bt_form .icon_prev:before,
.bt_form .icon_next:after {
  content:"";
  display:inline-block;
  width:10px;
  height:10px;
  border-top:3px solid #fff;
  border-right:3px solid #fff;
}
.bt_form .icon_prev:before {
  margin-right:15px;
  -webkit-transform:rotate(-135deg);
  transform:rotate(-135deg);
}
.bt_form .icon_next:after {
  margin-left:15px;
  -webkit-transform:rotate(45deg);
  transform:rotate(45deg);
}
.bt_form .submit[disabled="disabled"] span {
  background:#bbb;
  cursor:default;
}
.bt_form .submit[disabled="disabled"]:hover {
  opacity:1;
}

/* プレスホルダーカラー　*/
::-webkit-input-placeholder { color:#888; }
::-moz-placeholder { color:#888; opacity: 1; }
:-ms-input-placeholder { color:#888; }
:placeholder-shown { color:#888; }

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.form_area input[type="text"],
.form_area input[type="email"],
.form_area input[type="tel"],
.form_area textarea {
  max-width:100%;
  padding:5px 10px;
  font-size:1.4rem;
}
.bt_form {
  max-width:480px;
  margin:20px auto;
}
.bt_form li {
   margin:0 auto;
   width:48%;
}
.bt_form .bt_solo {
  width:100%;
  max-width:340px;
  padding:0 30px;
}
.bt_form li + li {
  margin-left:4%;
}
.bt_form span {
  display:block;
  width:100%;
  padding:10px;
  font-size:1.6rem;
}
}


/* ================================================================================
select
================================================================================= */
.select_wrap {
  width:100%;
  position:relative;
  display:inline-block;
}
.select_wrap::after {
  content:'';
  width:6px;
  height:6px;
  border:0px;
  border-bottom:solid 2px #bbb;
  border-right:solid 2px #bbb;
  -ms-transform:rotate(45deg);
  -webkit-transform:rotate(45deg);
  transform:rotate(45deg);
  position:absolute;
  top:50%;
  right:10px;
  margin-top:-5px;
}
.select {
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  width:100%;
  height:40px;
  background:transparent;
  position:relative;
  z-index:1;
  padding:0 40px 0 10px;
  border:1px solid #bbb;
  border-radius:0;
  font-size:1.5rem;
}
select::-ms-expand {
  display:none;
}
.select_wrap.select_prefectures {
  max-width:200px;
}
.select_wrap.select_date {
  max-width:140px;
}
.select_wrap.select_date + .select_date {
  margin-left:10px;
}
.select_none {
  display:none;
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.select {
  height:36px;
  font-size:1.4rem;
}
.select_wrap.select_prefectures {
  max-width:100%;
}
.select_wrap.select_date {
  max-width:100%;
}
.select_wrap.select_date + .select_date {
  margin:15px 0 0 0;
}
}


/* ================================================================================
radio
================================================================================= */
.radio_set li {
  display:inline-block;
}
.radio_set li + li {
  margin-left:30px;
}
.radio_set input[type="radio"],
.radio_set input[type="checkbox"] {
  margin-right:5px;
  vertical-align:middle;
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.radio_set li {
  display:block;
}
.radio_set li + li {
  margin:8px 0 0 0;
}
}


/* ================================================================================
form_contents
================================================================================= */
.form_contents .txt_supp {
  margin-bottom:30px;
  text-align:center;
}
.form_contents .txt_supp.co_01 {
  color:#c1272d;
}
.form_contents .icon_required {
  font-style:normal;
  font-weight:bold;
}
.form_contents .bt_check {
  margin-top:40px;
  text-align:center;
}
.form_contents .bt_check label {
  padding-left:5px;
}
.form_contents .form_add li {
  position:relative;
  padding-left:12em;
}
.form_contents .form_add li + li {
  margin-top:30px;
}
.form_contents .form_add li span {
  position:absolute;
  top:7px;
  left:0;
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.form_contents {
  margin:0 15px;
}
.form_contents .txt_supp {
  margin-bottom:15px;
}
.form_contents .bt_check {
  margin-top:30px;
}
.form_contents .form_add li {
  padding:0;
}
.form_contents .form_add li + li {
  margin-top:15px;
}
.form_contents .form_add li span {
  display:block;
  position:static;
  margin-bottom:3px;
  font-size:1.2rem;
}
}


/* ================================================================================
form_table
================================================================================= */
.form_table {
  width:860px;
  margin:0 auto;
}
.form_table th,
.form_table td {
  vertical-align:top;
  text-align:left;
  font-size:1.4rem;
}
.form_table th {
  position:relative;
  width:250px;
  padding:23px 0 15px 0;
}
.form_table th .icon_required {
  display:inline-block;
  position:absolute;
  right:25px;
  padding:1px 7px;
  border-radius:3px;
  color:#fff;
  font-size:1.3rem;
  background:#ff4600;
}
.form_table td {
  padding:15px 0;
}
.form_table .msg {
  color:#c1272d;
  font-weight:bold;
}
.form_table ul {
  padding-top:7px;
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.form_table {
  width:100%;
}
.form_table th,
.form_table td {
  display:block;
  width:100%;
  border:none;
}
.form_table th {
  padding:0 0 5px;
  font-size:1.3rem;
}
.form_table td {
  padding:0 0 15px;
}
.form_table tr:last-child th,
.form_table tr:last-child td {
  border-bottom:none;
}
.form_table th .icon_required {
  display:inline-block;
  position:static;
  margin-left:10px;
  padding:0 7px;
}
.form_table ul {
  padding-top:4px;
}
}


/* ================================================================================
tmpl_form テンプレート設定
================================================================================= */

/* PC調整 ----------------------------　*/
@media (min-width:769px) {
.tmpl_form .form_table th,
.tmpl_form .form_table td {
  padding:15px 0;
  border-bottom:1px solid #ccc;
  font-weight:500;
}
.tmpl_form .form_table tr:last-child th,
.tmpl_form .form_table tr:last-child td {
  border-bottom:none;
}
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.tmpl_form .form_table th {
  padding:7px 0 0;
  font-weight:500;
}
.tmpl_form .form_table td {
  padding:0 0 7px;
  border-bottom:1px solid #ddd;
}
}


/* ================================================================================
supp_box
================================================================================= */
.supp_box {
  margin-top:40px;
  text-align:center;
}
.supp_box .att {
  margin-top:20px;
  font-size:1.6rem;
}

/* SP調整 ----------------------------　*/
@media (max-width:768px) {
.supp_box {
  margin:10px 0 30px;
  text-align:left;
  font-size:1.3rem;
}
.supp_box .att {
  margin-top:1em;
  font-size:1.4rem;
}
}
