
/* リセット */

input[type="text"],
input[type="email"],
textarea {
    padding: 0;
    border: none;
    border-radius: 0;
    outline: none;
    background: none;
}

input[type="checkbox"],
input[type="radio"] {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

/* 問い合わせフォームパーツ */



input[type="text"],
input[type="email"],
textarea {
	vertical-align: middle;
	outline: none;
	background-color: #F7F9F4;
	border-width: 1px;
	border-style: solid;
	border-color: #D6D6D6;
}

input[type="text"],
input[type="email"] {
	width: 100% !important;
	padding:10px;
	font-size:16px;
	color: #333333;
}

textarea {
	width: 100% !important;
	height: 250px !important;
	padding:10px;
	font-size:16px;
	color: #333333;
}

.btms {
padding: 15px 40px;
font-size: 16px;
}

input#submit_button {
	display: inline-block;
	text-decoration: none;
	color: #007391;
	border: solid 2px #007391;
	border-radius: 3px;
    transition: .4s;
	padding-top: 20px;
	padding-right: 50px;
	padding-bottom: 20px;
	padding-left: 50px;
	font-size: 20px;
	background-color: #FFFFFF;
}

input#submit_button:hover {
    background: #007391;
    color: white;
}

button {
	color: #333333;
	}

button:hover {
	color: #676767;
	}

/* オリジナルボタン */
.original_btn {
    font-size: 16px;
	border: 1px solid #000;
	padding: 10px;
	cursor: pointer;
	color: #000;
	background: #fff;
	display: inline-block;
	width: 30% !important;
	margin-top: 10px;
}
/* 未選択時のアイコン */
.icon {
    font-size: 16px;
    padding: 10px;
	background-color: #F7F9F4;
    color: #000;
    display: inline-block;
	width: 65% !important;
	margin-top: 10px;
	border-width: 1px;
	border-style: solid;
	border-color: #D6D6D6;
}
/* 選択時のアイコン */
.icon.select {
    background: #ff5050;
    color: #fff;
	display: none;
}
/* ファイル名 */
.filename {
    display: inline-block;
    font-size: 16px;
    padding: 10px;
	width: 65% !important;
	background-color: #F7F9F4;
	border-width: 1px;
	border-style: solid;
	border-color: #D6D6D6;
}

.original_btn2 {
	width: 300px;
    font-size: 16px;
	border: 1px solid #000;
	padding-top: 15px;
	padding-bottom: 15px;
	cursor: pointer;
	color: #000;
	background: #fff;
	display: inline-block;
	margin-top: 10px;
	margin-right: auto;
	margin-left: auto;
}

.original_btn3 {
	width: 300px;
    font-size: 16px;
	border: 1px solid #000;
	padding-top: 15px;
	padding-bottom: 15px;
	cursor: pointer;
	color: #000;
	background: #fff;
	display: inline-block;
	margin-top: 10px;
	margin-right: auto;
	margin-left: auto;
}

input.short1 {
	width: 100px !important;
	padding:10px;
	font-size:14px;
	margin-right: 5px;
	margin-left: 5px;
}


/* タブレットサイズから下 */
@media screen and (max-width:992px) {
	
input[type="text"],
input[type="email"] {
	max-width: 800px !important;
	width: 100% !important;
	padding:10px;
	font-size:14px;
}
	
input.short1 {
	width: 100px !important;
	padding:10px;
	font-size:14px;
}
	
textarea {
	max-width: 800px !important;
	width: 100% !important;
	height: 250px !important;
	padding:10px;
	font-size:14px;
	height: 250px;
}
	
.original_btn2 {
	width: 50%;
	padding-top: 10px;
	padding-bottom: 10px;
	font-size: 14px;
}
	
.original_btn3 {
	width: 49%;
	padding-top: 10px;
	padding-bottom: 10px;
	font-size: 14px;
}
	
}

/* スマホサイズから下 */
@media screen and (max-width:480px) {

input[type="text"],
input[type="email"] {
	max-width: 800px !important;
	width: 100% !important;
	padding:5px;
	font-size:14px;
}
	
input.short1 {
	width: 80px !important;
	padding:5px;
	font-size:14px;
}
	
textarea {
	width: 100% !important;
	padding:5px;
	font-size:14px;
	height: 250px;
}
	
.original_btn2 {
	width: 100%;
	padding-top: 10px;
	padding-bottom: 10px;
	font-size: 14px;
	margin-top: 30px;
}
	
.original_btn3 {
	width: 49%;
	padding-top: 10px;
	padding-bottom: 10px;
	font-size: 14px;
	margin-top: 30px;
}
	
/* 未選択時のアイコン */
.icon {
    font-size: 16px;
    padding: 10px;
	background-color: #F7F9F4;
    color: #000;
    display: inline-block;
	width: 100% !important;
	margin-top: 10px;
}
/* 選択時のアイコン */
.icon.select {
    background: #ff5050;
    color: #fff;
}
/* ファイル名 */
.filename {
    display: inline-block;
    font-size: 16px;
	width: 65% !important;
}

}





/* ラジオボタン1、ボタンタイプ */

.radio01 {
  text-align: left;
}
.radio01 input[type="radio"] {
  display: none;
}
.radio01 input[type="radio"] + span {
    display: inline-block;
	cursor: pointer;
	width: 250px;
	height: 50px;
	line-height: 50px;
	background: #bdc3c7;
	color: #555e64;
	font-size: 16px;
	text-align: center;
	margin-top: 5px;
	margin-right: 0;
	margin-left: 0;
	margin-bottom: 0;
	padding: 0;
	transition: .2s;
	border-radius: 5px;
}

.radio01 input[type="radio"]:checked + span {
	color: #fff;
	background: #57d5df;
	font-weight: bold;
}

.radio01-yes {
	margin-top: 10px;
	width: 100%;
	display: block;
}

/* タブレットサイズから下 */
@media screen and (max-width:992px) {
	
.radio01 input[type="radio"] + span {
	display: block;
	width: 250px;
	height: 30px;
	line-height: 30px;
	font-size: 14px;
}
	
}

/* ラジオボタン2、通常タイプ */

.label_list {
  margin: auto;
  line-height: 1.3;
}
.label_list::after {
  display: block;
  content: '';
  clear: both;
}
.label_list_item {
	float: left;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	width: 100%;
}
.label_list_item label {
  position: relative;
  display: block;
  word-break: break-all;
	line-height: 170%;
}
.label_list_item label input[type="checkbox"] + span,
.label_list_item label input[type="radio"] + span {
  position: relative;
  padding: 0 30px 0 35px;
}

.demo2 .label_list:nth-of-type(1) label input[type="radio"] + span::before {
  border-color: #005bac;
}
.demo2 .label_list:nth-of-type(2) label input[type="radio"] + span::before {
  border-color: #ff5722;
}

.demo2 label span {
  display: inline-block;
}
.demo2 label input[type="radio"] {
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
}
.demo2 label input[type="radio"] + span::before {
  position: absolute;
  display: inline-block;
  content: '';
  box-sizing: border-box;
  border-radius: 22px;
}
.demo2 label input[type="radio"] + span::before {
  z-index: 0;
  top: 0;
  left: 0;
  background-color: transparent;
  width: 22px;
  height: 22px;
  border: 2px #78909c solid;
}
.demo2 label input[type="radio"]:checked + span::before {
  border-width: 6px;
}

/* 基礎のデザイン */

.red {
	color: #FF0000;
}

.w100 {
	width: 100%;
}

.t-c {
	text-align: center;
}

/* 基本のテーブル、MT50　PC */
.form_table01 table {
	border-collapse: collapse; 
	border-spacing: 0;
	width: 100%; 
	line-height: 1.3;
	margin-top: 50px;
}

.form_table01 table th {
	padding-top: 20px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 20px;
	width: 200px;
	font-size: 16px;
	border-bottom-color: rgb(238, 238, 238);
	border-bottom-width: 1px;
	border-bottom-style: solid;
	text-align: left;
	font-weight: 300;
}
.form_table01 table td {
	padding-top: 20px;
	padding-right: 15px;
	padding-left: 15px;
	padding-bottom: 20px;
	font-size: 16px; 
	border-bottom-color: rgb(238, 238, 238); 
	border-bottom-width: 1px; 
	border-bottom-style: solid;
	text-align: left;
	font-weight: 300;
}

.form_table01 .list1 dt {
	float: left;
}
.form_table01 table td .list1 dd {
	padding-left: 1.5em;
}
.form_table01 table td .list2 dt {
	float: left;
}
.form_table01 table td .list2 dd {
	padding-left: 13em;
}

/* テーブルレスポンシブ用　スマホ */
@media screen and (max-width:1005px) {

.form_table01 table {
	width: 100%;
	border-collapse: collapse; 
	border-spacing: 0;
	margin-top: 30px;
}

.form_table01 table th {
	background: rgb(221, 221, 221); 
	padding: 8px;
	width: 100%;
	display: block;
	font-size: 14px;
	border-bottom-width: 0; 
	border-bottom-style: none;
}
.form_table01 table td {
	background: rgb(255, 255, 255); 
	padding: 8px;
	width: 100%;
	display: block;
	font-size: 14px; 
	border-bottom-width: 0; 
	border-bottom-style: none;
}
.form_table01 table td .list2 dt {
	float: none;
	width: 100%;
	display: block;
}
.form_table01 table td .list2 dd {
	padding-left: 0em;
	width: 100%;
	display: block;
}


}




