@charset "utf-8";
/*== TOPページ ==*/
/*MV*/
.mv {
	margin: 0 auto;
	/*background-image: url(../images/top/pc/mv.jpg);*/
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: calc(100vh - 210px);
	position: relative;
}
.mv_video {
	height: calc(100vh - 210px);
	overflow: hidden;
}
.mv .container {
	position: absolute;
	bottom: -160px;
	left: 50%;
	transform: translateX(-50%);
	background-color: rgba(255,255,255,1);
	width: 60%;
	padding-top: 80px;
	padding-bottom: 90px;
	box-sizing: border-box;
	box-shadow: 5px 5px 5px rgba(0,0,0,0.3);
	height: 300px;
}
.mv .container h2 {
	font-size: 48px;
	font-size: 2.5vw;
	line-height: 1;
	text-align: center;
	/*font-weight: bold;*/
}
.mv .container p {
	font-size: 18px;
	font-size: 1vw;
	text-align: center;
	margin-top: 30px;
}

/*== scroll_down ==*/
#mv .scroll_down {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -50px;
	height: 100px;
}
	#mv .scroll_down::after {
		content: "";
		position: absolute;
		top: 0;
		width: 1px;
		height: 100px;
		background: #333;
		animation: pathmove 1.8s ease-in-out infinite;
		opacity: 0;
		z-index: 99;
	}
@keyframes pathmove{
	0% {
		height: 0;
		top: 0;
		opacity: 0;
	}
	30% {
		height: 50px;
		opacity: 1;
	}
	100% {
		height: 0;
		top: 100px;
		opacity: 0;
	}
}


@media screen and (max-width:1600px) {
	
}

@media screen and (max-width:1440px) {
	
}

@media screen and (max-width:1200px) {
	.mv {
	}
	.mv .container {
		height: auto;
		padding-top: 60px;
		padding-bottom: 60px;
	}
	.mv .container h2 {
		font-size: 4vw;
	}
	.mv .container p {
		font-size: 16px;
	}

}

@media screen and (max-width:599px) {
	.mv {
		/*background-image: url(../images/top/sp/mv.jpg);*/
		/*height: calc(100vh - 300px);*/
		/*height: calc(100vh - 150px);*/
		/*height: 100vh;*/
		/*height: 700px;*/
		padding-top: 50px;
	}
	.mv .container {
		width: 89.5%;
		padding-top: 40px;
		padding-bottom: 40px;
		bottom: -120px;
        background-color: rgba(255, 255, 255, .9);
        bottom: 45%;
        transform: translate(-50%, 50%);
	}
	.mv .container h2 {
		font-size: 6.5vw;
		font-size: 28px;
		line-height: 1.5;
	}
    .mv .container p {
        margin-top: 10px;
    }
	#mv .scroll_down {
		display: none;
	}
}



/*== About Us + Service ==*/
.article {
	padding: 150px 50px 50px;
	box-sizing: border-box;
}
.article:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-image: url(../images/common/pc/abstract_01.jpg);
	background-size: cover;
	width: 100%;
	height: 100%;
	background-attachment: fixed;
	z-index: -1;
}


/*== About Us ==*/
.about {
	padding-top: 200px;
	position: relative;
	z-index: 2;
}
.about .ttl_en {
	width: 580px;
	line-height: 0;
}
.about .inner {
	max-width: 1525px;
	width: 83.7913%;
	margin: 0 auto;
	margin-top: 50px;
}
.about .about_txt {
	max-width: 720px;
	width: 47.2132%;
}
.about .about_txt .content {
	background-color: rgba(255,255,255,.8);
	padding: 50px;
	/*box-shadow: 4px 4px 4px rgba(0,0,0,0.2);*/
}
.about .about_txt  h3.ttl_ja {
	text-align: left;
}
.about .about_txt h3.ttl_ja:before {
	bottom: 0;
	left: 0;
	transform: translateX(0);
}
.about .about_txt p {
	margin-top: 20px;
}


@media screen and (max-width:1600px) {
	
}

@media screen and (max-width:1440px) {
	.article {
		padding: 150px 30px 30px;
	}
	.about {
		padding-top: 120px;
	}
	.about .about_txt .content {
		padding: 30px;
	}
}
@media screen and (max-width:1300px) {
	.about .inner {
		width: 90%;
	}
	

}

@media screen and (max-width:1200px) {
	.about {
		padding-top: 80px;
	}
	.about .inner {
		display: block;
		width: 100%;
		position: relative;
		margin: 0;
	}
	.about .ttl_en {
		width: 325px;
	}
	.about .about_txt {
		max-width: 600px;
		width: 55%;
	}
	
}

@media screen and (max-width:599px) {
	.article {
		padding: 120px 5.25% 5.25%;
		padding: 0px 5.25% 5.25%;
	}
	.about {
        padding-top: 50px;
    }
	.about .ttl_en {
		width: 234px;
	}
	.about .inner {
		width: 100%;
	}
	.about .about_txt {
		width: 100%;
	}
	.about .about_txt .content {
		padding: 20px 20px 50px;
	}
	
}


/*about_item*/
.about_item {
	position: relative;
	max-width: 720px;
	width: 47.2132%;
	margin-left: 80px;
	margin-top: -200px;
	z-index: 9;
}
.about .photo_img {
	width: 100%;
	height: 100%;
}
.about .animation {
	position: absolute;
	top: -78px;
	left: -78px;
	width: min(var(--vw, 1vw)* 870 / 1360* 100, 870px);
	height: min(var(--vw, 1vw)* 870 / 1360* 100, 870px);
	animation-name: rotate;
	animation-duration: 40s;
	animation-timing-function: cubic-bezier(0.5, 0.51, 0.51, 0.52);
	animation-iteration-count: infinite;
}
.about .animation:before {
	content: "";
	padding-top: 50%;
}
@keyframes rotate{
  0% {
	transform: rotateZ(0);
  }
  100% {
	transform: rotateZ(360deg);
  }
}

.about .photo_img img {
	border-radius: 100%;
	overflow: hidden;
}

@media screen and (max-width:1850px) {
	.about .animation {
		width: 850px;
		height: 850px;
		top: -80px;
		left: -80px;
	}
}
@media screen and (max-width:1800px) {
	.about .animation {
		width: 830px;
		height: 830px;
	}
}
@media screen and (max-width:1750px) {
	.about .animation {
		width: 800px;
		height: 800px;
		top: -77px;
		left: -77px;
	}
}
@media screen and (max-width:1700px) {
	.about .animation {
		width: 770px;
		height: 770px;
		top: -70px;
		left: -70px;
	}
}
@media screen and (max-width:1650px) {
	.about .animation {
		width: 740px;
		height: 740px;
		top: -65px;
		left: -65px;
	}
}
@media screen and (max-width:1600px) {
	.about .animation {
		width: 720px;
		height: 720px;
	}
}
@media screen and (max-width:1550px) {
	.about .animation {
		width: 700px;
		height: 700px;
	}	
}
@media screen and (max-width:1500px) {
	.about .animation {
		width: 680px;
		height: 680px;
	}
}
@media screen and (max-width:1450px) {
	.about .animation {
		width: 640px;
		height: 640px;
		top: -57px;
		left: -57px;
	}
}
@media screen and (max-width:1400px) {
	.about .animation {
		top: -60px;
		left: -60px;
	}
}
@media screen and (max-width:1350px) {
	.about .animation {
		width: 620px;
		height: 620px;
	}
}
@media screen and (max-width:1300px) {
	.about .animation {
		top: -52px;
		left: -52px;
	}
}
@media screen and (max-width:1250px) {
	.about .animation {
		width: 600px;
		height: 600px;
	}
}
@media screen and (max-width:1200px) {
	.about_item {
		position: absolute;
		max-width: 400px;
		width: 100%;
		margin-left: 0;
		margin-top: 0;
		right: 50px;
		top: 0;
	}
	.about .animation {
		width: 500px;
		height: 500px;
		top: -50px;
		left: -50px;
	}
}
@media screen and (max-width:1024px) {
	.about_item {
		max-width: 340px;
	}
	.about .animation {
		width: 420px;
		height: 420px;
		top: -40px;
		left: -40px;
	}
}
@media screen and (max-width:850px) {
	.about_item {
		max-width: 270px;
		right: 30px;
		bottom: -100px;
		top: auto;
	}
	.about .animation {
		width: 340px;
		height: 340px;
        top: -36px;
        left: -36px;
	}
}
@media screen and (max-width:599px) {
	.about_item {
		position: relative;
		margin: 0 auto;
		right: 0;
		bottom: 0;
	}
}


/*== Service ==*/
.service {
	margin-top: -160px;
	position: relative;
	z-index: 1;
}
.service .ttl_en {
	width: 464px;
	line-height: 0;
}
.service .inner {
	padding-top: 140px;
	padding-bottom: 90px;
	background-color: rgba(255,255,255,0.9);
}
.services_list {
	max-width: 1300px;
	margin: 0 auto;
	margin-top: 90px;
	flex-wrap: wrap;
	position: relative;
}
.services_list:before {
	content: "";
	position: absolute;
	bottom: 100px;
	right: -110px;
	background-image: url(../images/top/pc/service_item.png);
	background-repeat: no-repeat;
	background-size: 530px;
	width: 530px;
	height: 430px;
}
.services_list li {
	max-width: 400px;
	width: 100%;
	position: relative;
	box-shadow: 4px 4px 4px rgba(0,0,0,0.2);
	margin-bottom: 50px;
}
.services_list li + li {
	margin-left: 50px;
}
.services_list li:nth-child(3n+1) {
	margin-left: 0;
}

.services_list li dl {}
.services_list li dl dt {
	position: relative;
}
.services_list li dl dt .number {
	font-size: 36px;
	width: 80px;
	height: 80px;
	line-height: 80px;
	display: inline-block;
	border-radius: 80px;
	background: rgb(218,164,32);
	background: linear-gradient(90deg, rgba(218,164,32,1) 0%, rgba(252,211,31,1) 100%);
	text-align: center;
	color: #fff;
	position: absolute;
	top: -40px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}
.services_list li dl dt h4 {
	font-size: 24px;
	color: #fff;
	padding: 20px 23px 18px;
	box-sizing: border-box;
	background: rgb(218,164,32);
	background: linear-gradient(90deg, rgba(218,164,32,1) 0%, rgba(252,211,31,0.8) 100%);
	position: absolute;
	bottom: 0;
	width: 100%;
	line-height: 1.4167;
}
.services_list li dl dd {
	padding: 25px;
}

@media screen and (max-width:1700px) {
	.service {
		margin-top: -50px;
	}
}

@media screen and (max-width:1600px) {
	.service {
		margin-top: 0;
	}
}

@media screen and (max-width:1440px) {
	.service .inner {
		padding-top: 80px;
		padding-bottom: 60px;
	}
	.services_list {
		width: 94%;
	}
	.services_list:before {
		bottom: 135px;
		right: -55px;
		background-size: 430px;
		width: 430px;
		height: 345px;
	}
	.services_list li {
		width: 32%;
	}
	.services_list li + li {
		margin-left: 30px;
		margin-left: 2%;
	}
	.services_list li dl dt h4 {
		font-size: 22px;
		padding: 18px 20px 16px;
	}
}

@media screen and (max-width:1300px) {
	.service .inner {
		padding-top: 60px;
		padding-bottom: 30px;
	}

}

@media screen and (max-width:1200px) {
	.service {
		margin-top: 80px;
	}
	.services_list {
		margin-top: 60px;
	}
	.services_list:before {
		right: 0;
	}
	.service .ttl_en {
		width: 266px;
	}
	.service .inner {
		padding-top: 50px;
		padding-bottom: 0;
	}
	.services_list li {
		max-width: initial;
		width: 48%;
	}
	.services_list li + li {
		margin-left: 4%;
	}
	.services_list li:nth-child(3n+1) {
		margin-left: 4%;
	}
	.services_list li:nth-child(2n+1) {
		margin-left: 0;
	}
	.services_list li dl dd {
		padding: 20px;
	}
	.services_list li dl dt h4 {
		font-size: 18px;
	}
}

@media screen and (max-width:899px) {
	.service {
		margin-top: 50px;
	}
	.services_list:before {
		right: -10%;
	}
}

@media screen and (max-width:599px) {
	.service {
		margin-top: 50px;
	}
	.service .ttl_en {
		width: 191px;
	}
	.service .inner {
		padding: 20px;
	}
	.services_list {
		margin-top: 50px;
		display: block;
		width: 100%;
	}
	.services_list li {
		width: 100%;
		margin-bottom: 0;
	}
	.services_list li + li {
		margin-left: 0;
		margin-top: 50px;
	}
	.services_list li:nth-child(3n+1) {
		margin-left: 0;
	}
	.services_list:before {
		content: none;
	}
}


/*== アウトソーシング業務 ==*/
.outsourcing {
	background-image: url(../images/top/pc/outsourcing.jpg);
	background-attachment: fixed;
	background-size: cover;
	position: relative;
}
.outsourcing:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(0,0,0,.4);
	width: 100%;
	height: 100%;
	z-index: 0;
}
.outsourcing .inner {
	padding-top: 180px;
	padding-bottom: 180px;
	position: relative;
}
.outsourcing_box {
	max-width: 900px;
	margin: 0 auto;
	border: 1px solid #fff;
}
.outsourcing_box p {
	text-align: center;
	color: #fff;
	font-size: 28px;
	padding-top: 100px;
	padding-bottom: 100px;
}

@media screen and (max-width:1200px) {
	.outsourcing .inner {
		padding: 100px 30px;
	}
	.outsourcing_box p {
		font-size: 3vw;
		padding-top: 80px;
		padding-bottom: 80px;
	}
}

@media screen and (max-width:599px) {
	.outsourcing {
		background-image: url(../images/top/sp/outsourcing.jpg);
		background-attachment: initial;
	}
	.outsourcing .inner {
		padding: 50px 5.25%;
	}
	.outsourcing_box p {
		font-size: 4vw;
	}
}


/*== Company ==*/
.company {
	background-color: #efefef;
	padding: 50px;
}
.company .ttl_en {
	width: 588px;
	line-height: 0;
	position: relative;
	z-index: 9;
}
.company .inner {
	margin-top: -35px;
	padding-top: 130px;
	padding-bottom: 130px;
	background-color: rgba(255,255,255,.9);
	position: relative;
}
.company .inner:before {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	background-image: url(../images/top/pc/company_bk.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 650px;
	opacity: .24;
	z-index: 0;
}
.overview {
	max-width: 900px;
	margin: 0 auto;
	margin-top: 40px;
	position: relative;
}
.overview dl {
	display: flex;
	flex-wrap: wrap;
	border-bottom: 1px solid #333;
	padding-top: 30px;
	padding-bottom: 30px;
}
.overview dl dt {
	max-width: 300px;
	width: 100%;
	padding-left: 35px;
	line-height: 2.2;
	box-sizing: border-box;
}
.overview dl dd {
	max-width: 600px;
	width: 100%;
	line-height: 2.2;
	padding-right: 35px;
	box-sizing: border-box;
}


@media screen and (max-width:1600px) {
	
}

@media screen and (max-width:1440px) {
	.company {
		padding: 30px;
	}
	.company .ttl_en {
		width: 332px;
	}
	.company .inner {
		padding: 80px 30px;
	}
	.overview dl {
		padding-top: 20px;
		padding-bottom: 20px;
	}
	.overview dl dt {
		font-size: 18px;
		padding-left: 10px;
	}
	.overview dl dd {
		padding-right: 0;
		padding-left: 10px;
		line-height: 1.8;
	}
}

@media screen and (max-width:1200px) {
	
}

@media screen and (max-width:599px) {
	.company {
		padding: 5.25%;
	}
	.company .ttl_en {
		width: 239px;
	}
	.company .inner {
		padding: 50px 20px;
        margin-top: -15px;
	}
	.overview {
		margin-top: 20px;
	}
}


/*== top_contact ==*/
.top_contact {
	background-image: url(../images/common/pc/abstract_02.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
}
.top_contact .inner {
	padding-top: 120px;
	padding-bottom: 120px;
}
.top_contact .contact_box {
	max-width: 480px;
	margin: 0 auto;
}
.top_contact .contact_box a {
	display: inline-block;
	width: 100%;
	height: 140px;
	background-color: #333;
	/*border-radius: 170px;*/
	color: #fff;
	position: relative;
	padding: 30px 0 20px 40px;
	box-sizing: border-box;
}
.top_contact .contact_box a:before {
	content: "";
	position: absolute;
	top: 60px;
	right: 60px;
	background-image: url(../images/common/pc/arrow.svg);
	background-repeat: no-repeat;
	background-size: 30px;
	width: 30px;
	height: 30px;
}
.top_contact .contact_box a:hover {
	background-color: #555;
}
.top_contact .contact_box a h3 {
	font-size: 50px;
	line-height: 1;
}
.top_contact .contact_box a span {

}


@media screen and (max-width:1600px) {
	
}

@media screen and (max-width:1440px) {
	
}

@media screen and (max-width:1200px) {
	.top_contact .inner {
		padding-top: 100px;
		padding-bottom: 100px;
	}
	.top_contact .contact_box {
		max-width: 540px;
	}
}

@media screen and (max-width:599px) {
	.top_contact .inner {
		padding-top: 50px;
		padding-bottom: 50px;
	}
	.top_contact .contact_box {
		width: 70%;
	}
	.top_contact .contact_box a {
		height: auto;
		padding: 20px 0 15px 20px;
	}
	.top_contact .contact_box a:before {
		top: 32px;
		right: 30px;
	}
	.top_contact .contact_box a h3 {
		font-size: 28px;
	}
	.top_contact .contact_box a span {
	    font-size: 14px;
	}
}


/*== #お問い合わせページ ==*/
.kv {
	height: 300px;
	position: relative;
}
.kv:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	background-image: url(../images/common/pc/abstract_02.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.kv h3.ttl_tips {
	width: 496px;
	padding-left: 50px;
	padding-top: 65px;
}
.contact {
	padding-top: 100px;
	padding-bottom: 100px;
}
.contact .contact_txt {
	text-align: center;
	font-size: 18px;
}
.contact .content {
	max-width: 1000px;
	margin: 0 auto;
}




@media screen and (max-width:1200px) {
	.kv {
		padding-top: 70px;
	}
	.kv h3.ttl_tips {
		width: 283px;
		padding-top: 90px;
	}
	.contact {
		padding-top: 50px;
		padding-bottom: 50px;
	}
}

@media screen and (max-width:599px) {
	.kv {
		padding-top: 55px;
		height: 250px;
	}
	.kv h3.ttl_tips {
		width: 203px;
	}
	.contact {
		padding-top: 30px;
	}
	.contact .contact_txt {
		padding-left: 5.25%;
		padding-right: 5.25%;
		text-align: left;
		font-size: 16px;
	}
}


/*お問い合わせフォーム*/
#formWrap {
	max-width: 940px;
	margin:0 auto;
	margin-top: 50px;
	box-sizing: border-box;
}
.formTable {
	display: block;
	width: 100%;
	margin: 0 auto;
	padding-left: 150px;
	padding-right: 150px;
	box-sizing: border-box;
	padding-top: 12px;
	padding-bottom: 50px;
	background-color: #efefef;
	border: none;
}

.formTable .textarea dt {
	padding: 30px 20px 0 0;
	vertical-align: top;
}

.formTable dd {
	max-width: 640px;
	width: 100%;
	padding-top: 0;
}
.formTable dt {
	font-weight:normal;
	text-align: left;
	border: none;
	padding: 38px 20px 0 0;
	box-sizing: border-box;
	color: #333;
}
.formTable dt .required {
	margin-left: 10px;
	background-color: #C1272D;
	padding: 3px 10px;
	font-size: 16px;
	color: #fff;
	border-radius: 5px;
}
.formTable dt .any {
	margin-right: 10px;
	background-color: #fff;
	padding: 3px 10px;
	font-size: 16px;
	color: #6E6E6E;
}
.formTable dd .record_area {
	padding: 10px 13px;
	border: 1px solid #ddd;
	color: #555;
	width: 100%;
	box-sizing: border-box;
	margin-top: 10px;
	height: 48px;
	font-size: 16px;
	padding-left: 15px;
	background-color: #fff;
}
.formTable .textarea dd .record_area {
	height: 230px;
}
.formTable dd .record_area:focus {
	outline: none;
}

input[type="submit"] {
	padding: 0;
	transition: .3s;
	cursor: pointer;
	background-color: #333; 
	color: #fff;
	width: 255px;
	height: 65px;
	font-size: 16px;
	-webkit-appearance: none;
	border: none;
	border-radius: 50px;
}
input[type="submit"]:hover {
	transition: .3s;
	background-color: #555;
	color: #fff;
}
input[type="button"] {
	padding: 0;
	border: 1px solid #999;
	transition: .3s;
	cursor: pointer;
	background-color: #999; 
	color: #fff;
	width: 255px;
	height: 65px;
	font-size: 18px;
	-webkit-appearance: none;
	border-radius: 50px;
}
input[type="button"]:hover {
	background-color: #444;
}
input[type="reset"] {
	padding: 10px 25px;
	margin-left: 20px;
	border: 1px solid #ddd;
	cursor: pointer;
	margin-left: 20px;
	border-radius: 0;
	-webkit-appearance: none;
	border-radius: 50px;
}
input[type="reset"]:hover {
	background-color: #dfdfdf;	
	transition: .5s;
}
@keyframes onAutoFillStart { from {} to {}}
input:-webkit-autofill {
	animation-name: onAutoFillStart;
	transition: background-color 50000s ease-in-out 0s;
}
/*　簡易版レスポンシブ用CSS（必要最低限のみとしています。ブレークポイントも含め自由に設定下さい）　*/
@media screen and (max-width:1200px) {
	#formWrap {
		max-width: initial;
		width: 100%;
	}
	.formTable {
		border-radius: 0;
		padding-left: 5.3334%;
		padding-right: 5.3334%;
	}
	.formTable dt {
		max-width: 640px;
		margin: 0 auto;
	}
	.formTable dd {
		margin: 0 auto;
	}

	#formWrap .privacy_txt {
		max-width: 640px;
	}
}

@media screen and (max-width:599px) {
#formWrap {
	width:100%;
	margin:0 auto;
	margin-top: 30px;
}
.formTable {
	border-radius: 0;
	padding-left: 5.3334%;
	padding-right: 5.3334%;
}
	.formTable dt,
	.formTable dd {
		width:auto;
		display:block;
	}
	.formTable dt {
		margin-top: 0;
		border-bottom: 0;
		padding-top: 20px;
	}
	.formTable dt .required {
		font-size: 14px;
	}
	.formTable dt .any {
		font-size: 14px;
	}
	.formTable .textarea dt {
		padding-top: 20px;
	}
	.formTable dd .record_area {
		margin-top: 8px;
	}
	input[type="submit"],
	input[type="reset"],
	input[type="button"] {
		height: 65px;
	}
}


/*プライバシーポリシー*/
#formWrap .privacy_txt {
	max-width: 750px;
	width: 100%;
	margin: 0 auto;
	font-size: 16px;
}
#formWrap .termsBox {
	max-width: 750px;
	width: 100%;
	margin: 0 auto;
	height: 250px;
	overflow-y: scroll;
	background-color: #fff;
	border: 1px solid #acadae;
	padding: 15px 10px;
	box-sizing: border-box;
	margin-top: 30px;
}
#formWrap .termsBox .scrollWrap dl + dl {
	padding-top: 15px;
}
#formWrap .termsBox .scrollWrap dl dt {
}
#formWrap .termsBox .scrollWrap dl dd {
	padding-top: 8px;
	font-size: 16px;
	line-height: 1.2;
}

#formWrap .privacy_check {
	display: none;
}
#formWrap .privacy_check .required {
	margin-right: 13px;
	background-color: #f9c270;
	padding: 5px 13px;
	border-radius: 5px;
	font-size: 14px;
	color: #fff;
}
#formWrap .privacy_check .text_check {
	display: inline-block;
	transform: translateY(1px);
}
#formWrap .privacy_check input[type="checkbox" i] {
	margin: 0;
	transform: scale(1.1);
}
#formWrap .form_btn {
	text-align: center;
	margin-top: 50px;
}


@media screen and (max-width:1200px) {
	#formWrap .termsBox {
		max-width: 640px;
	}
}

@media screen and (max-width:599px) {
	#formWrap .privacy_txt {
		max-width: 599px;
		padding-left: 5.3334%;
		padding-right: 5.3334%;
		box-sizing: border-box;
	}
	#formWrap .termsBox {
		margin-top: 30px;
		width: 89.5%;
	}
	#formWrap .form_btn {
		margin-top: 50px;
	}

}


/*== 確認ページ ==*/
#formWrap .formTable {
}
#formWrap .formTable tr {
	max-width: 640px;
	display: flex;
	flex-wrap: wrap;
	margin: 0 auto;
	/*color: #fff;*/
}
#formWrap .formTable th {
	text-align: left;
	font-weight: normal;
	border: none;
	padding: 38px 20px 0 0;
	box-sizing: border-box;
}
#formWrap .formTable td {
	width: 700px;
	padding: 10px 13px!important;
	border: 1px solid #ddd;
	color: #555;
	background-color: #fff;
	box-sizing: border-box;
	display: block;
	min-height: 48px;
}
#formWrap .formTable tr:last-child td {
	min-height: 230px;
}
input[type="button"] {
	margin-left: 20px;
}
.error_box input[type="button"] {
	margin-left: 0;
}
.error_h4 {
	font-size: 18px;
}
.error_h4 .error_txt {
	color: #f01;
	font-weight: bold;
}
.messe_box {
	margin-top: 50px;
	padding-left: 150px;
	padding-right: 150px;
	box-sizing: border-box;
	background-color: #F5F5F5;
	padding-top: 12px;
	padding-bottom: 50px;
	margin-bottom: 50px;
}
.error_messe {
	font-size: 18px;
	min-height: 48px;
	line-height: 48px;
	border-radius: 10px;
	box-sizing: border-box;
	margin-top: 38px;
}
.error_messe dt {
	max-width: 640px;
	text-align: left;
	border: none;
	box-sizing: border-box;
	line-height: 1;
}
.error_messe dt .required {
	margin-left: 10px;
	background-color: #C1272D;
	padding: 3px 10px;
	font-size: 16px;
	color: #fff;
	border-radius: 5px;
}
.error_messe dd {
	max-width: 640px;
	width: 100%;
	padding-top: 0;
	border: 1px solid #ddd;
	color: #888;
	width: 100%;
	box-sizing: border-box;
	border-radius: 6px;
	height: 48px;
	font-size: 16px;
	padding-left: 15px;
	background-color: #fff;
	text-align: left;
	margin-top: 10px;
}
@media screen and (max-width:1200px) {
	#formWrap .formTable tbody {
		width: 100%;
		display: block;
	}
	#formWrap .formTable tbody tr + tr {
		padding-top: 0;
	}
	#formWrap .formTable tbody tr th {
		max-width: initial;
		padding-bottom: 0px;
		padding-top: 20px;
	}
	#formWrap .formTable tbody tr td {
		margin: 0 auto;
		width: 100%;
	}
	.messe_box {
		padding-left: 5.3334%;
		padding-right: 5.3334%;
		border-radius: 0;
		padding-top: 30px;
		margin-top: 30px;
	}
}

@media screen and (max-width:599px) {
	input[type="button"] {
		margin: 0 auto;
	}
	input[type="submit"] {
		margin-bottom: 30px;
	}
	.error_messe {
		margin-top: 20px;
	}
	.error_messe dt {
		font-size: 16px;
	}
	.error_messe dt .required {
		font-size: 14px;
	}
}

/*== サンクスページ ==*/
#contact.thanks {
	padding-top: 130px;
	padding-bottom: 130px;
}
	p.tanks_ttl {
		font-size: 36px;
		text-align: center;
	}
	#contact.thanks .thanks_box {
		max-width: 1200px;
		margin: 0 auto;
	}
		#contact.thanks .thanks_box .tanks_txt {
			margin-bottom: 50px;
			font-size: 18px;
			margin-top: 30px;
			text-align: center;
		}
		p.top_back {
			text-align: center;
		}
		#contact.thanks .thanks_box .top_back a {
			display: inline-block;
			max-width: 275px;
			width: 100%;
			height: 80px;
			line-height: 80px;
			background-color: #333;
			color: #fff;
			font-size: 18px;
			text-align: center;
			box-sizing: border-box;
			border-radius: 50px;
		}
			#contact.thanks .thanks_box .top_back a:hover {
				transition: .3s;
				background-color: #555;
			}


@media screen and (max-width:1200px) {
	#contact.thanks {
		padding-top: 80px;
		padding-bottom: 80px;
	}
}
@media screen and (max-width:599px) {
	#contact.thanks {
		padding-top: 50px;
		padding-bottom: 50px;
	}
	p.tanks_ttl {
		font-size: 28px;
	}
	#contact.thanks .thanks_box .tanks_txt {
		font-size: 18px;
	}
	#contact.thanks .thanks_box .top_back a {
		font-size: 16px;
		max-width: 240px;
		width: 100%;
		height: 65px;
		line-height: 65px;
	}
	#contact.thanks .thanks_box .top_back a:before {
		bottom: 24px;
	}
}