@charset "UTF-8";
/* CSS Document */

/*******ここから↓*****/
::placeholder {
  color: #a2a2a2;
  font-weight:300;
}
textarea::placeholder { 
  color: #a2a2a2;
  font-weight:300;
  opacity: 0.8;
}
#main { 
	padding-bottom:0px;
}

textarea{border:1px solid #9fa0a0;}

#area{background-color: #fff;
    padding-top: 0vw;
    padding-bottom: 5vw;}
.area_box{width: 69.2vw;
      margin: auto;}
.area_main{margin:0 auto;}
*, *:before, *:after {
  box-sizing: border-box;
}

p{
	font-size: 0.8rem;
	font-weight: 100;
	line-height: 2em;
	letter-spacing: 0.15rem;
}

a.pp{text-decoration: underline;}

dl,dt,dd {
  margin: 0;
  padding: 0;

}


dl.table {

  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin-top:35px;
  margin-bottom:30px;
  align-items: center;
}

dt,dd{

	padding:10px 10px;
}

dl dt{
	font-size: 0.8rem;
	font-weight: 300;
	line-height: 2em;
	width:22%;
	white-space:nowrap;


}
dl dd{
	font-size:107.7%;
	font-weight:300;
	width:78%;
	white-space:nowrap;
}



input[type="text"] { width: 100%; }

input[type=radio] {
  margin-right: 5px;
  padding-top:-3px;
}

input[type=email] {
	box-sizing:border-box;
	border-style: none;
	padding:20px;
	background-color: #eeeeec;
	width:100%;

}

label{padding-right:15px;margin-bottom:5px;}
.vertical-align input,
.vertical-align select{
	vertical-align:middle;
}

input[type="text"],
select,
textarea{
	box-sizing:border-box;
	border-style: none;
	padding:20px;
	background-color: #eeeeec;

}

textarea{
	height:15em;
	width:100%;
	line-height:1.4;
	background-color: #eeeeec;
}

.sizeS{ width:5em;}
.sizeM{ width:20em;}
.sizeL{ width:80%;}

.btnArea{ text-align:center; padding:30px 0;}
.btnArea li{
	display:inline-block;
	padding:0 10px;
}

input[type="submit"]{
	

	color:#000;
	font-size:107.7%;
	border:none;
	cursor:pointer;
	-webkit-appearance: button;

}

input[type="submit"]:hover{ background:#222;}

input.back{
	background:#DADADA;
	color:#000;
}

input.back:hover{ background:#CCC;}

.mailChk{
	padding:0.5em 0;	
}

.att{
	color:000;
	
}

.backTop{ text-align:center; padding:45px 0 100px;}
.backTop a{
	display:inline-block;
	min-width:15em;
	height:40px;
	line-height:40px;
	background:#000;
	padding:0 10px;
	color:#FFF;
	font-size:107.7%;
	border:none;
	cursor:pointer;
}
.btnArea{
	width:192px;
	padding:10px 20px;
  border: 1px solid #000000;
  border-radius: 25px;
  margin:2vw auto;
}

#agreement{margin-bottom:20px;max-width: 676px;border:none;}
p#agree_check{margin-top:-2px;}

form#mail_form p#form_submit {
	width: 90%;
	margin: 0 auto;
	padding: 15px 0;

}

form#mail_form input[type="button"] {
	font-size: 1vw;
	font-weight: bold;
  color: #fff;
  width:18.66vw;
  text-align: center;
  background: #000;
  border-radius: 1.16vw;
  padding: 1.25vw 1.25vw;
  position: relative; /* 追記 */
	margin:0.83vw auto 0vw;
	border: solid 1px #000;

  font-family : "游ゴシック","Yu Gothic" ,"游ゴシック体","ヒラギノ角ゴ ProN W3",'Hiragino Kaku Gothic Pro',"Meiryo UI","メイリオ","Meiryo","MS Pゴシック","MS PGothic",sans-serif;
}

form#mail_form input[type="button"]:hover {
	cursor: pointer;
	background: #E8410B;
	color:#fff;
	border: 1px solid #E8410B;
}

form#mail_form input#form_submit_button {
	margin-left: 35%;
}

input[type="checkbox"]{
  vertical-align:middle;
}

/******フォーム入力選択時の設定↓*****/

input[type="text"],
textarea,input[type="email"] {
  outline: none;
  border: none;
  -webkit-transition: all .3s;
  transition: all .3s;
}
input[type="text"]:focus,
textarea:focus,input[type="email"]:focus{
  box-shadow: 0 0 3px #000;
  border: none;
}



	.policy {
		overflow:auto; height:180px;
		padding:0.5vw 3vw 3vw 3vw;
		border:none;
		color:#e8e8e8;
		background-color:#eeeeec;
		line-height:1.5em;
		margin:50px 0;
	}
	.policy p {
		color:#000;
		font-weight:500;
		font-size:80%;
		letter-spacing: 0.1rem;
	}

	h4{
color:#000;

 font-weight:500;
 font-size:150%;

}
/********** 矢印ここから */
.b-text-scroll {
			position: absolute;
			top: 25vw;
			left: 4vw;
			width: 2%;
			margin: 0 auto;
			text-align: center;

			z-index: 101;
		}
		.b-text-scroll img {
			display: block;
			width: 100%;
			height: auto;
		}
		.b-text-scroll .arrow {
			position: absolute;
			width: 60%;
			/*bottom: -220%;*/
			bottom: calc(-500 / 1920 * 100vw);
			left: 2px;
			animation: sdb 1.5s infinite;
		}
.b-text-scroll {
			position: absolute;
			top: 15vw;
			left: 3vw;
			width: 1vw;
			z-index: 50;
		}

		.b-text-scroll .arrow {
			position: absolute;
			width: 60%;
			/*bottom: -220%;*/
			bottom: calc(-230 / 1920 * 100vw);
			left: 2px;
		}
		@keyframes sdb {
		  0% {
			transform: translate(0, 0);
			opacity: 0;
		  }
		  50% {
			opacity: 1;
		  }
		  100% {
			transform: translate(0, 15px);
			opacity: 0;
		  }
		}
		@media screen and (max-width:750px) {
		.b-text-scroll {
			position: absolute;
			top: 25vw;
			left: 4vw;
			width: 2%;
			margin: 0 auto;
			text-align: center;

			z-index: 101;
		}
		.b-text-scroll img {
			display: block;
			width: 100%;
			height: auto;
		}
		.b-text-scroll .arrow {
			position: absolute;
			width: 60%;
			/*bottom: -220%;*/
			bottom: calc(-500 / 1920 * 100vw);
			left: 2px;
			animation: sdb 1.5s infinite;
		}
		}
		@media screen and (min-width:1301px) {
			/* 矢印ここから */
		.b-text-scroll {
			top: 195px;
			left: calc( (100% - 1220px) / 2 );
			width: 13px;
		}
		.b-text-scroll .arrow {
			width: 780;
			bottom: calc(-230 / 1920 * 1300px);
			left: 2px;
		}
		 /* 矢印ここまで */
		}
 /************* 矢印ここまで */

@media screen and (min-width:751px) and ( max-width:1300px) {
/*ここからtopback*/
.topback{
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 8vw;
  padding: 20px;
  cursor: pointer;
  transition: .3s;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
z-index: 105;
}

/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}
/*ここまでtopback*/
}



/**********************************ここからtablet用のcssを記述*********************************/
@media screen and (max-width:750px) {
/*******ここから↓*****/
/*ここからtopback*/
.topback{
  position: fixed;
  right: 0;
  bottom: 0;
  width: 20vw;
  cursor: pointer;
  transition: .3s;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
z-index: 105;
}
/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}
/*ここまでtopback*/	

#main #area .areabox .areamain h3{
 font-size:3vw;
}
#area{background-color: #fff;
		padding-top: 1vw;
		padding-bottom:5vw;
	    overflow:hidden;	
	}
.area_box{width: 88vw;
			max-width: 1100px;
			margin: auto;}

a.pp{text-decoration: underline;}

dl,dt,dd {
  margin: 0;
  padding: 0;
}

dl.table {

  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin-top:35px;
  margin-bottom:30px;
  align-items: center;
}

dt,dd{

	padding:10px 10px;
}

dl dt{
	font-size:107.7%;
	font-weight:300;
	width:22%;
	white-space:nowrap;

}
dl dd{
	font-size:107.7%;
	font-weight:300;
	width:75%;
	white-space:nowrap;
}

input[type="text"] { width: 100%; }

input[type=radio] {
  margin-right: 5px;
  padding-top:-3px;
}

input[type=email] {
	box-sizing:border-box;
	border-style: none;
	padding:20px;
	background-color: #eeeeec;
	width:100%;
}

label{padding-right:15px;margin-bottom:5px;}
.vertical-align input,
.vertical-align select{
	vertical-align:middle;
}

input[type="text"],
select,
textarea{
	box-sizing:border-box;
	border-style: none;
	padding:20px;
	background-color: #eeeeec;

}

textarea{
	height:15em;
	width:100%;
	line-height:1.4;
	background-color: #eeeeec;
}

.sizeS{ width:5em;}
.sizeM{ width:20em;}
.sizeL{ width:80%;}

.btnArea{ text-align:center; padding:30px 0;}
.btnArea li{
	display:inline-block;
	padding:0 10px;
}

input[type="submit"]{
	

	color:#000;
	font-size:107.7%;
	border:none;
	cursor:pointer;
	-webkit-appearance: button;

}

input[type="submit"]:hover{ background:#222;}

input.back{
	background:#DADADA;
	color:#000;
}

input.back:hover{ background:#CCC;}

.mailChk{
	padding:0.5em 0;	
}

.att{
	color:000;
	
}

.backTop{ text-align:center; padding:45px 0 100px;}
.backTop a{
	display:inline-block;
	min-width:15em;
	height:40px;
	line-height:40px;
	background:#000;
	padding:0 10px;
	color:#FFF;
	font-size:107.7%;
	border:none;
	cursor:pointer;
}
.btnArea{
	width:192px;
	padding:10px 20px;
  border: 1px solid #000000;
  border-radius: 25px;
  margin:2vw auto;
}

#agreement{margin:0 auto 20px;max-width: 676px;border:none;}
p#agree_check{margin-top:-2px;}

form#mail_form p#form_submit {
	max-width:40vw;
text-align : center ; 


}

label{font-size:3.5vw;}

form#mail_form input[type="button"] {
	font-size:2.5vw;
  width:41.6vw;
  border-radius: 3.4vw;
  padding: 3.125vw 3.125vw;
  font-weight:800;
  font-family : "游ゴシック","Yu Gothic" ,"游ゴシック体","ヒラギノ角ゴ ProN W3",'Hiragino Kaku Gothic Pro',"Meiryo UI","メイリオ","Meiryo","MS Pゴシック","MS PGothic",sans-serif;
}

form#mail_form input[type="button"]:hover {
	cursor: pointer;
	background: #000;
	color:#fff;
	border: 1px solid #000;
}

form#mail_form input#form_submit_button {
	margin: 0;
}

input[type="checkbox"]{
  vertical-align:middle;
}

input[type="text"],
textarea {
  outline: none;
  border: none;
  -webkit-transition: all .3s;
  transition: all .3s;
}
input[type="text"]:focus,
textarea:focus {
  box-shadow: 0 0 3px #000;
  border: none;
}

dl.table {

  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin-top:35px;
  margin-bottom:30px;
  align-items: center;
}

dt,dd{

	padding:0;
}

dl dt{
	font-size:3.5vw;
	font-weight:300;
	width:100%;
	white-space:nowrap;
	margin-bottom:1vw;

}
dl dd{
	font-size:107.7%;
	font-weight:300;
	width:100%;
	white-space:nowrap;
	margin-bottom:6vw;
}


h4{
color:#000;

 font-weight:500;
 font-size:130%;

}

	.policy {
		overflow:auto;height:50vw;
		padding:0.5vw 5vw 5vw 5vw;
		border:none;
		color:#e8e8e8;
		background-color:#eeeeec;
		line-height:1.5em;
		margin:10vw 0;
	}
	.policy p {
		color:#000;
		font-weight:500;
		font-size:70%;
		letter-spacing: 0.1rem;
	}


/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {
	margin-right: 1em;
	margin-bottom: 2em;
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */



/*******ここまで↑*****/	
}



/*************************************************ここから1300以上のcssを記述*/
@media screen and (min-width: 1301px) {
/*******ここから↓*****/
/*ここからtopback*/
.topback{
  position: fixed;
  right: 25px;
  bottom: 25px;
  width: 100px;
  padding: 20px;
  cursor: pointer;
  transition: .3s;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
z-index: 105;
}

/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}
/*ここまでtopback*/
#area{background-color: #fff;
		padding-bottom: 60px;}
.area_box{width: 1100px;}

.area_main{
	width: 900px;}

a.pp{text-decoration: underline;}

dl,dt,dd {
  margin: 0;
  padding: 0;
}

dl.table {

  width: 100%;
  display: flex;
  flex-wrap: wrap;
  margin-top:35px;
  margin-bottom:30px;
  align-items: center;
}

dt,dd{

	padding:10px 10px;
}

dl dt{
	font-size:13px;
	font-weight:300;
	width:22%;
	white-space:nowrap;

}
dl dd{
	font-size:107.7%;
	font-weight:300;
	white-space:nowrap;
}
dl dd p{
	font-size:100%;
	margin-top:3px;
	font-weight:300;
	line-height:1.5;
	letter-spacing: 0.1rem;
}

dt.aket{margin-top:-22px;}

input[type="text"] { width: 100%; }




input[type=radio] {
  margin-right: 5px;
  padding-top:-3px;
}

input[type=email] {
	box-sizing:border-box;
	border:1px solid #9fa0a0;
	padding:20px;
	background-color: #eeeeec;
	width:100%;
}

label{padding-right:15px;margin-bottom:5px;}
.vertical-align input,
.vertical-align select{
	vertical-align:middle;
}

input[type="text"],
select,
textarea{
	box-sizing:border-box;
	border-style: none;
	padding:20px;
	background-color: #eeeeec;

}



.sizeS{ width:5em;}
.sizeM{ width:20em;}
.sizeL{ width:80%;}

.btnArea{ text-align:center; padding:30px 0;}
.btnArea li{
	display:inline-block;
	padding:0 10px;
}

input[type="submit"]{
	

	color:#000;
	font-size:107.7%;
	border:none;
	cursor:pointer;
	-webkit-appearance: button;

}

input[type="submit"]:hover{ background:#222;}

input.back{
	background:#DADADA;
	color:#000;
}

input.back:hover{ background:#CCC;}

.mailChk{
	padding:0.5em 0;	
}

.att{
	color:000;
	
}

.backTop{ text-align:center; padding:45px 0 100px;}
.backTop a{
	display:inline-block;
	min-width:15em;
	height:40px;
	line-height:40px;
	background:#000;
	padding:0 10px;
	color:#FFF;
	font-size:107.7%;
	border:none;
	cursor:pointer;
}
.btnArea{
	width:192px;
	padding:10px 20px;
  border: 1px solid #000000;
  border-radius: 25px;
  margin:2vw auto;
}

#agreement{max-width: 676px;border:none;}
p#agree_check{margin-top:-2px;}

form#mail_form div#form_submit {
	width: 90%;
	margin: 0 auto;
	padding: 15px 0;

}

form#mail_form input[type="button"] {
  font-size: 15px;
  color: #fff;
  width:250px;
  text-align: center;
  background: #000;
  border-radius: 20px;
  border: 1px solid #000000;
  padding: 15px 15px;
  position: relative; /* 追記 */
  margin:0 auto 50px;
  font-weight:800;
  font-family : "游ゴシック","Yu Gothic" ,"游ゴシック体","ヒラギノ角ゴ ProN W3",'Hiragino Kaku Gothic Pro',"Meiryo UI","メイリオ","Meiryo","MS Pゴシック","MS PGothic",sans-serif;
}

form#mail_form input[type="button"]:hover {
	cursor: pointer;
	background: #E8410B;
	color:#fff;
	border: 1px solid #E8410B;
}



h4{
color:#000;

 font-weight:500;
 font-size:150%;
 letter-spacing: 0.15rem;

}

	.policy {
		overflow:auto;
		max-width:900px; height:180px;
		padding:0.5vw 3vw 3vw 3vw;
		border:none;
		color:#e8e8e8;
		background-color:#eeeeec;
		line-height:1.5em;
		margin:50px 0;
	}
	.policy p {
		color:#000;
		font-weight:500;
		font-size:80%;
		letter-spacing: 0.1rem;
	}










form#mail_form input#form_submit_button {
	margin-left: 35%;
}

input[type="checkbox"]{
  vertical-align:middle;
}


/******フォーム入力選択時の設定↓*****/

input[type="text"],
textarea,input[type="email"] {
  outline: none;
  border: none;
  -webkit-transition: all .3s;
  transition: all .3s;
}
input[type="text"]:focus,
textarea:focus,input[type="email"]:focus{
  box-shadow: 0 0 3px #E8410B;
  border: none;
}

/******フォーム枠の入力後の色、文字色↓*****/	
input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px white inset;
    -webkit-text-fill-color: #000 !important;
}



/*******ここまで↑*****/	
}





/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {

	display : inline-block;
	
	color : #ffffff;
	line-height : 1;
	padding : 15px 9px;
	margin-right:7px;
	border-radius : 6px;

}

form#mail_form dl dt span.required {
	background : #000;
	border : 1px solid #000;
}


form#mail_form dl dt span.optional {
	background : #777;
	border : 1px solid #777;
}

form#mail_form dl dd span.error_blank,
form#mail_form dl dd span.error_format,
form#mail_form dl dd span.error_match {
	display: block;
	color: #ff0000;
	margin-top: 3px;
}


span.loading {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	border-top: 5px solid rgba( 255, 255, 255, 0.2 );
	border-right: 5px solid rgba( 255, 255, 255, 0.2 );
	border-bottom: 5px solid rgba( 255, 255, 255, 0.2 );
	border-left: 5px solid #ffffff;
	-webkit-transform: translateZ( 0 );
	-ms-transform: translateZ( 0 );
	transform: translateZ( 0 );
	-webkit-animation: load-circle 1.0s linear infinite;
	animation: load-circle 1.0s linear infinite;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -30px;
	margin-left: -30px;
}

@-webkit-keyframes load-circle {
	0% {
		-webkit-transform: rotate( 0deg );
		transform: rotate( 0deg );
	}
	100% {
		-webkit-transform: rotate( 360deg );
		transform: rotate( 360deg );
	}
}

@keyframes load-circle {
	0% {
		-webkit-transform: rotate( 0deg );
		transform: rotate( 0deg );
	}
	100% {
		-webkit-transform: rotate( 360deg );
		transform: rotate( 360deg );
	}
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */
