

/*===============================================*/

/*  form.css */

/*===============================================*/

/*//////////////////////////////////

form
///////////////////////////////////*/


.form-Wrap {
	margin: 0px auto 30px;
	padding:0; }

.form-Wrap .kome {margin-bottom:50px; }
.form-Wrap .kome p {font-size: 1.6rem!important;}
.form-Wrap .kome span {color:#e60012; display: block;}

@media screen and (max-width: 768px){
.form-Wrap .kome {margin-bottom:10px; }
.form-Wrap .kome p {font-size: 1.5rem!important;}
}

.thanks{
	margin:0px auto;
	padding:150px 0;
	width:100%;
	font-family: 'Noto Sans JP', sans-serif;
	height:auto; }

.thanks h2,.thanks p{
	width:100%;
	height:auto;
	text-align:center;
	font-size:18px;
	line-height:30px;
	font-family: 'Noto Sans JP', sans-serif;}

/**/

.icon-req {
	display: inline-block;
	padding: 0.5rem 1rem;
	
	text-align: center;
	font-size:1.2rem;
	line-height:12px;
	font-weight:500;
	letter-spacing: 0.1em;
	color: #fff;
	background-color:#e60012; }

.icon-nonreq {
	display: inline-block;
	padding: 0.5rem 1rem;
	
	text-align: center;
	font-size:1.2rem;
	line-height:12px;
	font-weight:500;
	letter-spacing: 0.1em;
	color: #fff;
	background-color:#AAAAAA; }



/*---------------------------------*/

.formArea .formInner{
	margin:0px auto 0px;
	padding:0px 0px 0px;
	width:100%; }

.formArea .formInner dl{
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #DDDDDD;  }
	
.formArea .formInner dl dt{
	margin: 0px 0px 0px 0px;
	padding:8px 1.6rem 0px 0px;
	width:250px;
	font-size: 1.6rem;
	font-family: 'Noto Sans JP', sans-serif;}

.formArea .formInner__Confirm dl dt {
    padding: 0 1.6rem 0 0;
    width: 280px;
}
.formArea .formInner dl dt img{width:40px;float:right;}

.formArea .formInner dl dd {
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 1.6rem;
    width: calc(100% - 250px);
    font-size: 1.6rem;
    font-family: 'Noto Sans JP', sans-serif;
}

.formArea .formInner__Confirm dl dd {
    width: calc(100% - 280px);
}

.hankaku {
	margin-top: 10px;
    font-size: 1.4rem;
	color: #555555;
	line-height: 1;
}

.pp-scroll {
    height: 290px;
    margin-bottom: 20px;
    padding: 3rem;
    overflow-x: hidden;
    overflow-y: scroll;
    border: #dddddd 1px solid;
}

.form__Link a{color:#3068AA; text-decoration: underline; line-height: 1.5; transition: 0.25s;} 

.form__Link a:hover {opacity: 0.6; text-decoration: none;}
	

/* input */
input,
select{
    font-family: revert;
    line-height: revert;
}
input[type=text],
input[type=password],
textarea,
select{
  padding: 1.5rem;
  font-size:1.6rem;
  border:1px solid #CCCCCC;
  transition:border-color .1s linear;
  outline: none; 
	background-color: #FAFAFA;
	border-radius: 5px!important;}

::placeholder {color: #A0A0A0;}

input[type=text]:focus,
input[type=password]:focus,
textarea:focus{
  background: #fff!important;
  border:solid 1px #e60012!important;
  padding: 1.5rem!important; }

input[type=text].ss-size{width:20px;}
input[type=text].s-size{width:90px;}
input[type=text].m-size{width:200px;}
input[type=text].l-size{width:364px;}
input[type=text].ll-size{width:780px;}
input[type=text].fit-size{width:100%;box-sizing:border-box;}
label{margin-right: 10px;}
input[type=text],
input[type=password],
input[type=submit],
input[type=button],
textarea,
select{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  appearance:none;
  border-radius: 0; }

select{width: 100%;}
select.s-size{width: 25%;}
select.m-size{width: 50%;}
textarea{width:100%; height: 200px; box-sizing:border-box;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;}

:-moz-any(select):before {
  background-color: #fff; /* this is necessary for overcome the caret default browser */
  pointer-events: none; /* https://developer.mozilla.org/en-US/docs/Web/CSS/pointer-events  */
  z-index: 1; /* this is necessary for overcome the pseudo element */ }

select{
  background:url(../img/common/icon_arw.png) no-repeat 95%;
  background:none\9;
  text-indent: .01px; /*Firefox*/
  text-overflow: ""; /*Firefox*/ }

select::-ms-expand{
  display:none; }

select:focus{
  padding: 18px 20px 18px 18px;
  background:#fff url(../img/common/icon_arw.png) no-repeat 95%;
  background:none\9;
  text-indent: .01px; /*Firefox*/
  text-overflow: ""; /*Firefox*/ }

.complete{
  background:#fff!important;
  border:solid 1px #d1d1d1!important; }

.form-title{
  /*margin-bottom:15px;*/
  padding-left:10px;
  font-size:1.2rem!important;
  color: #777 ;
  min-width: 174px;
  display: inline-block; }

.btnbox{
	position: relative;z-index: 9;
	margin:50px auto 100px;
}
.inquiry-btnbox {
    justify-content: center;
    gap: 15px;
}


input[type=submit] {
    outline: none;
}

input[type=submit].submit-btn,
input[type=button].submit-btn {
	display: block;
	width: 160px;
	padding: 12px;
	color:#ffffff;
	background: #3068AA;
	border: none;
	text-align: center;
	text-decoration: none;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 600;
	overflow: hidden;
	will-change: transition;
	cursor: pointer;
	border-radius: 50px;
	transition: 0.3s all cubic-bezier(0.215, 0.61, 0.355, 1);
}

input[type=submit].submit-btn:hover,
input[type=button].submit-btn:hover {
	color: white; opacity: 0.6; }

#Clear {
    color: #111111;
    background-color: #eee;
}
/*
input[type=submit].submit-btn[disabled],
input[type=button].submit-btn[disabled],{
  background-color: #ccc;
  cursor: not-allowed; 
}*/
/**/
input[type="radio"] {
    display: none;
    /*checked時の見た目*/
}
input[type="radio"] + label {
  display:inline-block;
  cursor: pointer;
  margin: 8px 30px 0 0;
}
input[type="radio"] + label::before {
  width: 25px;
  height: 25px;
  display: inline-block;
  content: "";
  border-radius: 17px;
  vertical-align: middle;
  border: 1px solid #dddddd;
  background-color: #fff;
  margin: -2px 5px 0 0;
  -webkit-transition: .1s;
  transition: .1s;
}
/*
input[type="radio"] + label:hover {
  color: #808080; }*/

input[type="radio"] + label:hover::before {
  background-color: #fff; }

input[type="radio"]:checked + label {
  color: #3068AA;
  cursor: default; }

input[type="radio"]:checked + label::before {
  background-color: #3068AA !important;
  box-shadow: inset 0 0 0 3px #fff; }


/* チェックボックス01 */
input[type=checkbox] {
    display: none;
}
.checkbox01 {
    box-sizing: border-box;
    cursor: pointer;
    display: inline-block;
    padding: 7px 10px 0 30px;
    position: relative;
    width: auto;
}
.checkbox01::before {
    background: #fff;
    border: 1px solid #dddddd;
    content: '';
    display: block;
    height: 25px;
    left: 0px;
    margin-top: -8px;
    position: absolute;
    top: 50%;
    width: 25px;
}
.checkbox01::after {
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    content: '';
    display: block;
    width: 8px;
    height: 14px;
    left: 10px;
    margin-top: -7px;
    opacity: 0;
    position: absolute;
    top: 22px;
    transform: rotate(45deg);
}
input[type=checkbox]:checked + input[type=hidden] + .checkbox01::after {
    opacity: 1;
}

input[type=checkbox]:checked + input[type=hidden] + .checkbox01::before {
    background: #3068AA;
}


/*===============================================*/

/*  for tablet     画面の横幅が768px-958pxまで */

/*===============================================*/


@media screen and (max-width: 959px){
	
/*entry
--------------------------------*/
.formWrap h4 {text-align:left;}
section.formArea{width:100%;}
section.formArea .formInner dl{margin-bottom: 10px;}
section.formArea .formInner dl dt{margin: 0px 0px 5px 0px;width:100%;float:none;}
section.formArea .formInner dl dd{width:100%;float:none;}
input[type=submit].btn,
input[type=button].btn {margin:30px 0 0;width: 100%;}
input[type=text].m-size{width:100%;}
select.m-size{width: 100%;}
}
/*===============================================*/





/*===============================================*/

/*  for SP   画面の横幅が768px以下 */

/*===============================================*/

@media screen and (max-width: 768px){
.form-Wrap {margin: 0px auto ;padding:0 0rem; }
 .checkbox01 {display: block;padding: 7px 10px 0 30px;}
input[type="radio"] + label {display:block;margin: 8px 30px 0 0;}

}
/*===============================================*/


