@charset "utf-8";
/* CSS Document */



/* ===========================================================
 form(SP)
=========================================================== */

.body_tbl {
  background: #f4f4f4;
  padding: 0 0 10vw;
}

.body_tbl .smp_tmpl .ttl {
  text-align: center;
  padding: 8vw 0;
  font-size: 4vw;
  font-weight: 700;
  background: #ddd;
  border-top: solid 1px #ccc;
  border-right: solid 1px #ccc;
  border-left: solid 1px #ccc;}

.body_tbl .bodyttl {
  position: relative;
  text-align: center;
  padding: 12vw 0 2vw;
}

.body_tbl .bodyttl:after {
  content: "";
  width: 100%;
  display: block;
  border-bottom: solid 1px #333;
  position: relative;
  top: -3vw;
  z-index: 0;
}

.body_tbl .bodyttl span {
  font-size: 5vw;
  padding: 0 6vw;
  background: #f4f4f4;
  position: relative;
  z-index: 1;
  letter-spacing: 0.5vw;
  text-align: center;
  display: inline-block;
  line-height: 6vw
}


.body_tbl .header_rmesg,
.body_tbl .header_emesg {
  text-align: center;
  margin: 0 0 6vw;
  font-size: 3.2vw;
  padding: 6vw 8vw 0;
  line-height: 4vw
}

.body_tbl .header_emesg {
  color: red;
}

.body_tbl form {
  margin: 0 auto;
}

.body_tbl .smp_tmpl {
  border-bottom: solid 1px #d9d9d9;
}

.body_tbl dl {
  width: 100%;
}


.body_tbl .title {
  font-size: 3.6vw;
  font-weight: 700;
  background: #e8eff7;
  padding: 6vw 4vw;
  border-bottom: solid 1px #d9d9d9;
  border-top: solid 1px #d9d9d9;
  position: relative;
}


.body_tbl .title span {
  background: #e37280;
  border-radius: 0.5vw;
  color: #fff;
  padding: 2vw;
  font-size: 2.7vw;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 6vw;
  transform: translateY(-50%);
}


.body_tbl .title .others {
  font-size: 2.7vw;
  font-weight: 400;
  margin: 3vw 0 0;
  padding: 0 20vw 0 0;
  line-height: 4vw;
}

.body_tbl .data {
  background: #fff;
  width: 100%;
  padding: 5vw;
}

/* メールアドレス用（クラス付与必須） */
.body_tbl .data.address {
  line-height: 10vw
}

.body_tbl .data input {
  border: solid 1px #d9d9d9;
  width: 100%;
  padding: 2vw;
}

/* エラーメッセージ */
.body_tbl .data .msg {
  color: red;
  font-size: 2.7vw;
  margin: 3vw 0 0;
  display: block;
}


/* セレクト用 */
.body_tbl .data select  {
  border: solid 1px #ccc;
  padding: 3vw;
}

/* 電話番号用 */
.body_tbl .data.phone ul {
  display: flex;
  align-items: center;
  justify-content: center;
}

.body_tbl .data.phone ul li {
  padding: 0 0.5vw;
}

.body_tbl .data.phone ul li input {
  width: 25vw;
}


/* 日付用 */
.body_tbl .data.time ul {
  display: flex;
  align-items: center;
} 

.body_tbl .data.time ul li {
  padding: 0 2vw;
}

.body_tbl .data.time ul li input {
  width: 12vw;
  margin: 0 1vw 0 0;
}

  
/* 郵便番号用 */
.body_tbl .data.zipcode ul {
  display: flex;
  align-items: center;
}

.body_tbl .data.zipcode ul li {
  padding: 0 0.5vw;
}

.body_tbl .data.zipcode ul li input {
  width: 30vw;
}



/* ラジオボタン用 */
.body_tbl .multi2 ul.radio li {
  padding: 0 4vw;
  margin: 0 0 3vw;
}

.body_tbl .multi2 ul.radio li input[type="radio"] {
  width: auto;
  margin: 0 2vw 0 0;
  display: inline-block;
  vertical-align: 0;
}


/* チェックボックス用 */
.body_tbl .multi2 ul:not(.radio) li {
  margin: 0 0 3vw;
  position: relative;
  padding: 0 0 0 10vw;
  line-height: 5vw
}

.body_tbl .multi2 ul:not(.radio) li input[type="checkbox"] {
  width: auto;
  position: absolute;
  top: 0;
  left: 3vw;
}


/* テキストボックス用 */
.body_tbl .data textarea {
border: solid 1px #ccc;
  width: 89vw;
  height: 16.5vw;
  font-size: 3.8vw;
  padding: 2vw 3vw;
  margin: 0 auto 4vw;
  display: block;
} 
  


  
/* 送信ボタン */
.body_tbl .submit {
  background: #f5673a;
  color: #fff;
  font-size: 5vw;
  padding: 2vw 0;
  display: block !important;
  width: 52vw;
  margin: 8vw auto;
}



/* 設置先用 */
.body_tbl .setti {
  padding: 6vw 14vw;
  text-align: center;
  background: #fdf9da;
  border-top: solid 1px #ccc;
  border-left: solid 1px #ccc;
  border-right: solid 1px #ccc;
  font-size: 4vw;
  line-height: 5vw;
}

.body_tbl .yellow {
  background: #f9f6e4;
}

.cautionList {
  border-top: solid 1px #ccc;
}

.cautionList .ttl {
  margin: 10vw 0 6vw;
  font-size: 4.5vw;
  font-weight: 700;
  text-align: center;
}

.cautionList ul li {
  font-size: 3.2vw;
  line-height: 4vw;
  text-align: left;
  margin: 0 5.5vw 6vw;
}
	
.cautionList ul li a {
  display: inline;
  color: #1a81d0;
  text-decoration: underline;
}

.cautionList .cautionLast {
  font-size: 3.6vw;
  font-weight: 700;
  margin: 10vw 5.5vw 0;
  line-height: 5vw;
}
