@charset "utf-8";

ol {
	list-style-type: decimal;
	list-style-position: inside;
}

.main-inner {
	display: block;
	margin: 5rem auto;
}

.contact-box-title {
	color: #111111;
}

.heading01 {
	position: relative;
	padding-top: 30px;
	font-size: 2rem;
	border-bottom: 1px solid rgba(0, 0, 0, 0.2);
}

.heading01 span {
	position: relative;
	z-index: 2;
}

.heading01::before {
	content: attr(data-en);
	position: absolute;
	top: -20px;
	left: 0;
	color: rgba(0, 0, 0, 0.1);
	font-size: 10rem;
	text-transform: uppercase;
	z-index: 1;
	font-family: 'Josefin Sans', sans-serif;
	font-weight: bold;
}

.step-box {
	width: 100%;
	margin: 7rem auto 5rem;
}

.step-box ul {
	display: flex;
	justify-content: center;
	align-items: center;
	list-style: none;
}

.step-box li {
	height: 10rem;
	padding: 1.5rem;
	width: 30%;
	position: relative;
	color: #999999;
	background-color: #f1f1f1;
	border-radius: 7px;
	margin-right: 5%;
}

.step01 span,
.step02 span,
.step03 span {
	font-size: 2.5rem;
	font-family: 'Josefin Sans', sans-serif;
}

.step-box p {
	margin-top: 5px;
}


.step01::after,
.step02::after {
	content: "";
	width: 0;
	height: 0;
	border-top: 16px solid transparent;
	border-left: 16px solid #f1f1f1;
	border-bottom: 16px solid transparent;
	border-right: 16px solid transparent;
	position: absolute;
	right: -31px;
	top: 50%;
	margin-top: -16px;
}

.step-box .active {
	color: #ffffff;
	background-color: #666666;
}

.step-box .active::after {
	content: "";
	width: 0;
	height: 0;
	border-top: 16px solid transparent;
	border-left: 16px solid #666666;
	border-bottom: 16px solid transparent;
	border-right: 16px solid transparent;
	position: absolute;
	right: -31px;
	top: 50%;
	margin-top: -16px;
}

.step-box .step03 {
	margin-right: 0;
}

.step-box .step03-active {
	margin-right: 0;
	color: #ffffff;
	background-color: #666666;
}

#formWrap .formWrap-text {
	margin-bottom: 2rem;
}

#formWrap .messe-style {
	text-align: center;
}

.form-box-flex {
	display: flex;
	align-items: center;
}

.form-box-flex-last {
	display: flex;
	align-items: flex-start;
	margin-top: 2rem;
}

#formWrap .form-box dt {
	width: 35%;
	padding: 1rem 0;
	color: #111111;
}

#formWrap .form-box dd {
	width: 65%;
	padding: 1rem;
}

#main form,
#main form input,
#main form textarea,
#main form select {
	font-size: 1.5rem;
}

#main form dd input[type="text"],
#main form dd textarea {
	color: #111111;
	padding: 1rem;
	border: solid 1px #c7c7c7;
	border-radius: 3px;
}

#main form dd input[type="text"] {
	width: 60%;
}

#main form dd textarea {
	width: 100%;
}

#formWrap .form-box dt span {
	color: #EA047E;
}

.item-style {
	padding: 0.5rem 0;
}

.checkbox-area {
	margin-bottom: 2rem;
}

.button-box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 70%;
	margin: 0 auto;
}

form .button-box input[type="submit"],
form .button-box input[type="reset"],
.kakunin input[type="submit"],
.kakunin input[type="reset"],
.kakunin input[type="button"] {
	border: 1px solid #666666;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
	width: 48%;
	height: 60px;
	background-color: #666666;
	font-size: 1.6rem;
	color: #ffffff;
	text-align: center;
	line-height: 60px;
	border-radius: 5px;
	text-decoration: none;
}

form .button-box input[type="reset"],
.kakunin input[type="button"] {
	background-color: #ffffff;
	color: #666666;
}

form .button-box input[type="submit"]:hover,
.kakunin input[type="submit"]:hover {
	transform: scale(1.02);
	transition: .3s;
	background-color: #111111;
	border: #111111;
}

form .button-box input[type="reset"]:hover,
.kakunin input[type="reset"]:hover,
.kakunin input[type="button"]:hover {
	transform: scale(1.02);
	transition: .3s;
	color: #ffffff;
	background-color: #111111;
	border: #111111;
}

.notice {
	margin: 3rem 0;
}

.text-style h4 {
	margin: 3rem auto 2rem;
}

.kakunin h3 {
	margin: 5rem auto 1rem;
	text-align: center;
	font-size: 1.4em;
	color: #111111;
}

.kakunin #formWrap {
	margin-bottom: 4rem;
}

.kakunin #formWrap table.formTable {
	width: 100%;
	margin: 3rem auto 8rem;
	border-collapse: collapse;
}

.kakunin #formWrap table.formTable th,
.kakunin #formWrap table.formTable td {
	border: 1px solid #e6e6e6;
	padding: 1.5rem;
}

.kakunin #formWrap table.formTable th {
	width: 30%;
	text-align: left;
	color: #111111;
}

.pkobo-copyright {
	display: none;
}

/* thanks */
.thanks-box {
	margin: 3rem auto;
}

.thanks-box h3 {
	margin: 5rem auto;
	text-align: center;
	font-size: 1.4em;
	color: #111111;
}

.kanryo .button-box a {
	display: block;
	width: 70%;
	height: 60px;
	padding: 0;
	margin: 3rem auto;
	border: 1px solid #666666;
	cursor: pointer;
	outline: none;
	appearance: none;
	background-color: #666666;
	font-size: 1.6rem;
	color: #ffffff;
	text-align: center;
	line-height: 60px;
	border-radius: 5px;
	text-decoration: none;
}

.kanryo .button-box a:hover {
	transform: scale(1.02);
	transition: .3s;
	color: #ffffff;
	background-color: #111111;
	border: 1px solid #111111;
}

.privacy .privacy-title {
	width: 100%;
	padding: 0.7rem 2rem;
	margin: 2rem auto;
	color: #ffffff;
	background-color: #111111;
	font-size: 2rem;
	font-weight: bold;
	border-radius: 5px;
	text-align: center;
}

.privacy .privacy-area {
	width: 100%;
	height: 250px;
	overflow: auto;
	font-size: 1.4rem;
	margin: 1rem auto 2rem;
	padding: 1.4rem;
	border: 1px solid rgba(0, 0, 0, 0.2);
}

.privacy .privacy-area h3 {
	color: #111111;
	text-align: center;
	border-left: none !important;
	margin-top: 0 !important;
}

.privacy .privacy-area .ceo-box {
	text-align: right;
	margin-bottom: 2rem;
}

.privacy .privacy-area h4 {
	margin-top: 2rem;
	margin-bottom: 1rem;
	font-weight: bold;
}

.privacy .privacy-area ol {
	padding-left: 2rem;
}

.privacy .privacy-text {
	line-height: 1.8;
}

.privacy .privacy-text a {
	text-decoration: none;
}

.kaiji-box {
	padding: 1rem;
	border: 1px solid #111111;
	border-radius: 5px;
}


@media screen and (max-width:768px) {

	.main-inner {
		margin: 2rem auto;
	}

	.company-box-title {
		border: none;
	}

	.heading01::before {
		top: 0;
		font-size: 4.5rem;
	}

	#formWrap .messe-style {
		text-align: left;
	}

	.form-box-flex,
	.form-box-flex-last {
		display: block;
		margin-bottom: 2rem;
	}

	.step-box {
		margin: 3rem auto;
	}

	.step01 span,
	.step02 span,
	.step03 span {
		font-size: 1.5rem;
	}

	#formWrap .form-box dt {
		width: 100%;
	}

	#formWrap .form-box dd {
		width: 100%;
		padding: 0;
	}

	#main form dd input[type="text"] {
		width: 100%;
	}

	.button-box {
		display: block;
		width: 100%;
		text-align: center;
	}

	form .button-box input[type="submit"],
	form .button-box input[type="reset"],
	.kakunin input[type="submit"],
	.kakunin input[type="reset"],
	.kakunin input[type="button"] {
		width: 100%;
		height: auto;
		padding: 3rem;
		margin: 1rem auto;
		line-height: 0;
	}

	.formError {
		left: auto !important;
		right: 1rem !important;
	}

	.formError .formErrorContent {
		min-width: 14rem;
		font-size: 1.6rem;
	}

	.kakunin #formWrap table.formTable th,
	.kakunin #formWrap table.formTable td {
		display: block;
		width: 100%;
		padding: 1rem 0;
		border: none;
	}

	.kakunin #formWrap table.formTable td {
		border-bottom: 1px solid #e6e6e6;
	}

	.thanks-box {
		width: 100%;
	}

	.thanks-box h3 {
		margin: 3rem auto;
	}

	.kanryo .button-box a {
		width: 100%;
	}

}