@charset "UTF-8";

#contact_form_block #contact_box{
  color: #000;
}

.headline {
  background: url(../img/contact/headline.jpg) no-repeat center center/ cover;
}
/*-----------------------------------
	base
-----------------------------------*/
.wpcf7-list-item{
	margin: 0;
}
.wpcf7-spinner{
	display: none;
}

/*-----------------------------------
	#contact_block
-----------------------------------*/


/* reset */
#contact_form_block #contact_box input[type="submit"],
#contact_form_block #contact_box input[type="button"] {
  -webkit-appearance: none;
}

/* .w150 { */
  /* width: 150px; */
/* } */
/* .w400 { */
  /* width: 400px; */
/* } */
/* .w600 { */
  /* width: 600px; */
/* } */
#contact_form_block #contact_box .require {
	color: #0078d4;
	font-weight: 800;
	margin-left: 5px;
  font-size: 13px;
}
/* #contact_block { */
	/* position: relative; */
/* } */
#contact_form_block .intro_text {
  display: block;
  line-height: 200%;
  margin: 0 auto;
  padding:0 0 1.5em;
}
#contact_form_block .intro_text .thanks {
  display: block;
  font-size: 18px;
  color: #329a64;
  text-align: center;
  margin-bottom: 1.5em;
}
#contact_form_block .form_content {
  display: grid;
  grid-template-columns: 160px 1fr; /* 左: dt、右: dd */
  row-gap: 10px;
  column-gap: 10px;
}
.form_content dt.vertical {
  grid-column: 1 / 3; /* dt を横幅いっぱいに */
}

.form_content dd.vertical {
  grid-column: 1 / 3; /* dd も横幅いっぱいに */
}
.form_content dt.w_100{
  grid-column: 1 / 3;
  display: flex;
  justify-content: center;
  align-items: center;
}
#contact_form_block .form_content dt{
	/* padding-bottom: 10px; */
	font-size: 15px;
}
#contact_form_block .form_content dd {
  padding: 0 0 10px;
  font-size: 15px;
}
#contact_form_block .form_content dd.check_row,
.wpcf7-form-control-wrap .wpcf7-form-control{
	display: grid;
  grid-template-columns: repeat(4, 1fr); /* PCでは4列 */
  gap: 10px 10px;
}
.privacy_check .wpcf7-form-control-wrap .wpcf7-form-control{
  display: block;
}
/* #training_form_block .form_content dt:not(:last-of-type), */
/* #training_form_block .form_content dd:not(:last-of-type) { */
  /* border-bottom: 1px dotted #e7e7e7; */
/* } */
#contact_form_block .form_content dt {
	width: 100%;
	font-size: 14px;
	font-weight: 600;
}
#contact_form_block .form_content dd {
	width: 100%;
  word-break: break-all;
}
#contact_form_block input,
#contact_form_block textarea {
  font-size: 14px;
	padding: 0.7em;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  -ms-border-radius: 5px;
  -o-border-radius: 5px;
	border-radius: 5px;
	border: 1px solid #e9e9e9;
  cursor: pointer;
}
#contact_form_block input[type="text"],
#contact_form_block input[type="email"],
#contact_form_block input[type="tel"] {
  -webkit-appearance: none;
  width: 100%;
}
#contact_form_block textarea {
	resize: vertical;
	width: 100%;
	height: 200px;
  -webkit-appearance: none;
}
#contact_box input::placeholder {
  color: #d3d3d3;
}
/* IE */
#contact_box input:-ms-input-placeholder {
  color: #d3d3d3;
}
/* Edge */
#contact_box input::-ms-input-placeholder {
  color: #d3d3d3;
}
#contact_form_block .btn_area {
	margin: 30px 0 50px 0;
  display: flex;
  justify-content: center;
  align-items: center;
	text-align: center;
}
#contact_form_block .submit_btn {
  font-weight: 400 !important;
  display: inline-block;
  width: 350px;
  margin: 0 auto;
  padding: 23px 10px;
  background: #00a4ea;
  color: #fff;
  border: none;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1em;
  cursor: pointer;
  -webkit-transition: all 0.15s;
  -moz-transition: all 0.15s;
  transition: all 0.15s;
  outline: none;
}
#contact_form_block .submit_btn.back {
  margin-right: 5em;
  color: #2d2d2d;
  background: #efefef;
  border-color: #e8e8e8;
}
#contact_form_block .submit_btn:hover {
  background: #fff;
  border-color: #0078d4;
  color: #000;
}
/* #contact_form_block .submit_btn.back:hover { */
  /* background: #fff; */
  /* border-color: #ddd; */
  /* color: #2d2d2d; */
/* } */

@media screen and (max-width: 900px) {
	#contact_form_block .submit_btn {
		display: block;
		margin: 0 auto !important;
	}
  #contact_form_block .btn_area{
    flex-direction: column;
  }
	#contact_form_block .submit_btn.back {
		margin-bottom: 15px !important;
	}
}
@media screen and (max-width: 840px) {
	
  /* .w600 { */
    /* width: 100%; */
  /* } */
  /* #training_form_block .intro_text { */
    /* width: 80%; */
  /* } */
  /* #training_form_block .form_content dt { */
    /* width: 25%; */
  /* } */
  /* #training_form_block .form_content dd { */
    /* width: 75%; */
  /* } */

}

@media screen and (max-width: 640px) {
  .w150, .w400 {
    width: 100%;
  }
	#contact_form_block {
		padding: 0 0 40px;
	}
  #contact_form_block .intro_text {
    width: 100%;
    padding: 0 0 30px;
  }
  #contact_form_block .form_content dt,
  #contact_form_block .form_content dd {
    width: 100%;
  }
  #contact_form_block .form_content dt {
    border-bottom: none!important;
    padding-bottom: 10px;
  }
  #contact_form_block .form_content dd{
	padding: 0 0 20px;
  }
  #contact_form_block .form_content dd.check_row,
.wpcf7-form-control-wrap .wpcf7-form-control{
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
  }
  /* #training_form_block .form_content dd { */
    /* padding: 1.5em 0; */
  /* } */
  #contact_form_block input,
  #contact_form_block textarea {
    font-size: 16px;
    vertical-align: -2px;
    margin-right: 10px;
  }
  #contact_form_block .btn_area {
    margin-top: 15px;
  }
  #contact_form_block .submit_btn {
  	max-width: 100% !important;
  	font-size: 14px;
  	padding: 18px 10px;
  }
  #contact_form_block .back_btn {
    margin-right: 2.5em;
  }
}
@media screen and (max-width: 430px) {
  #contact_form_block .form_content {
    display: grid;
    grid-template-columns: repeat(1, 1fr); /* 左: dt、右: dd */
    row-gap: 10px;
    column-gap: 10px;
  }
  #contact_form_block .form_content dt, #contact_form_block .form_content dd {
    grid-column: 1 / 3; 
  }
  #contact_form_block .form_content dt{
    padding-bottom: 0;
  }
  #contact_form_block .form_content dd{
    padding-bottom: 5px;
  }
}
  
/*-----------------------------------

	radio

-----------------------------------*/
#contact_form_block .input_radio {
  display: none;
}
#contact_form_block .input_radio + label {
  padding-left: 1.5em;
  position: relative;
  margin-right: 2em;
  cursor: pointer;
}
#contact_form_block .input_radio + label::before {
  content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 18px;
    height: 18px;
    border: 1px solid #656565;
    border-radius: 50%;
    background: #fff;
}
#contact_form_block .input_radio:checked + label {
  color: #7dbd39;
}
#contact_form_block .input_radio:checked + label::before {
  border-width: 5px;
}

/*-----------------------------------

	radio

-----------------------------------*/
#contact_form_block .checkbox{
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  /* width: 33%; */
  margin-bottom: 10px;
  cursor: pointer;
}
.wpcf7-form-control-wrap .wpcf7-list-item{
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 10px;
}
.wpcf7-form-control-wrap .wpcf7-list-item label{
  cursor: pointer;
}
.privacy_check .wpcf7-form-control-wrap .wpcf7-list-item {
  margin-bottom: 0;
  font-weight: 600;
}
#contact_form_block .checkbox:hover {
  opacity: 0.8;
}
#contact_form_block .checkbox:nth-of-type(3n) {
/*	margin-right: 0;*/
}
@media screen and (max-width: 1100px) {
	#contact_form_block .checkbox ,
  .wpcf7-form-control-wrap .wpcf7-list-item{
		/* width: 49.5% */
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#contact_form_block .checkbox ,
  .wpcf7-form-control-wrap .wpcf7-list-item{
		display: block;
		width: 100%
	}
}
/*-----------------------------------

	error/alert

-----------------------------------*/
.error {
  color: red;
  font-size: 14px;
  padding-bottom: 0.3em;
}
.alert {
  display: block;
  padding: 0.5em;
  text-align: center;
  border: 1px solid red;
  background: rgba(255,0,0,0.1);
  color: red;

}

/*-----------------------------------

	recaptcha

-----------------------------------*/
.g-recaptcha {
	margin: 20px 0 50px !important;
}


/*-----------------------------------
	complete
-----------------------------------*/
#contact_form_block.complete h3{
	margin-bottom: 10px;
	font-weight: 700;
	font-size: 20px;
}
#contact_form_block.complete h3,
#contact_form_block.complete p{
	text-align: center;
}
#contact_form_block.complete p{
  margin-bottom: 50px;
}

@media screen and (max-width: 840px) {
}
@media screen and (max-width: 640px) {
	#contact_form_block.complete h3,
	#contact_form_block.complete p{
		text-align: left;
	}
}