@charset "UTF-8";

/*ob_lead
----------------------------------------*/
.ob_lead {
	background: #F8F7F7;
	color: #000;
	text-align: center;
	padding: 270px 20px 94px;
	margin: -162px 0 0;
}
.ob_lead h2 {
	font-size: 3.6rem;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: .05em;
	margin-bottom: 27px;
}
.ob_lead h2::after {
	content: '';
	display: block;
	width: 70px;
	height: 1px;
	background: #E7380D;
	margin: 15px auto 0;
}
.ob_lead p {
	font-size: 1.6rem;
	line-height: 2.1;
	letter-spacing: .05em;
	margin-bottom: 0;
}
.ob_lead p.note {
	font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
	.ob_lead {
		padding: 30px 6.9767% 50px;
		margin: 0;
	}
	.ob_lead h2 {
		font-size: 2.1rem;
	}
	.ob_lead p.note {
		text-align: left;
		line-height: 1.6;
		text-indent: -1em;
		margin-left: 1em;
	}
}

/*ob_occupation
----------------------------------------*/
.ob_occupation {
	padding: 8.5rem 2rem 0;
	color: #000;
}
.ob_occupation h2 {
	font-size: 3.4rem;
	font-weight: 500;
	letter-spacing: .05em;
	text-align: center;
	margin-bottom: 4.3rem;
}
.ob_occupation h3 {
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: .05em;
	margin-bottom: 3.9rem;
}
.ob_occupation h3 span {
	display: inline-block;
	padding-bottom: .1rem;
	border-bottom: .4rem solid #E7380D;
}
.ob_occupation .inner {
	max-width: 100rem;
	margin: 0 auto;
}
.ob_occupation .list {
	display: flex;
	margin-bottom: 3.5rem;
}
.ob_occupation .list li {
	width: 16.8rem;
	padding: 0;
	margin-left: 4rem;
	display: flex;
	justify-content: flex-end;
	flex-direction: column;
}
.ob_occupation .list li:first-child {
	margin-left: 0;
}
.ob_occupation .list .circle {
	width: 16.8rem;
	height: 16.8rem;
	background: #F1EFEF;
	color: #C4C4C4;
	border-radius: 50%;
	font-size: 1.6rem;
	line-height: 1.5;
	letter-spacing: .05em;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	font-weight: bold;
}
.ob_occupation .list .circle p {
	margin: 0;
}
.ob_occupation .list .balloon + .circle {
	background: #E7380D;
	color: #fff;
}
.ob_occupation .list .balloon {
	width: 10.6rem;
	border: .3rem solid #E7380D;
	border-radius: .6rem;
	line-height: 1.3;
	font-size: 1.6rem;
	color: #E7380D;
	font-weight: bold;
	margin: 0 auto 1.2rem;
	letter-spacing: .05em;
	padding: .2rem .3rem .4rem;
	text-align: center;
	position: relative;
}
.ob_occupation .list .balloon::before {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1rem .6rem 0;
	border-color: #E7380D transparent transparent;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -1rem;
	margin: 0 auto;
}
.ob_occupation .list .balloon::after {
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1rem .6rem 0;
	border-color: #fff transparent transparent;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -.5rem;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	.ob_occupation {
		padding: 4rem 6.9767% 0;
	}
	.ob_occupation h2 {
		font-size: 2.6rem;
		margin-bottom: 3rem;
	}
	.ob_occupation h3 {
		font-size: 2rem;
		margin-bottom: 3rem;
	}
	.ob_occupation .list {
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.ob_occupation .list li {
		margin-left: 0;
		margin-bottom: 3rem;
		width: 40vw;
	}
	.ob_occupation .list .circle {
		width: 40vw;
		height: 40vw;
		font-size: 4vw;
	}
}

/*ob_about
----------------------------------------*/
.ob_about {
	padding: 3.7rem 2rem 0;
	color: #000;
}
.ob_about h2 {
	font-size: 3.4rem;
	font-weight: 500;
	letter-spacing: .05em;
	text-align: center;
	margin-bottom: 3.1rem;
}
.ob_about .inner {
	max-width: 1000px;
	margin: 0 auto;
}
.ob_about h3 {
	color: #E7380D;
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: .05em;
	margin: 2.9rem 0 1.6rem;
}
.ob_about p {
	font-size: 1.6rem;
	letter-spacing: .05em;
	line-height: 1.5;
}
@media screen and (max-width: 767px) {
	.ob_about {
		padding: 3rem 6.9767% 0;
	}
	.ob_about h2 {
		font-size: 2.6rem;
		margin-bottom: 3rem;
	}
	.ob_about p {
		font-size: 1.5rem;
	}
}

/*ob_flow
----------------------------------------*/
.ob_flow {
	padding: 7.6rem 2rem 10.9rem;
	color: #000;
}
.ob_flow h2 {
	font-size: 3.4rem;
	font-weight: 500;
	letter-spacing: .05em;
	text-align: center;
	margin-bottom: 6.5rem;
}
.ob_flow .inner {
	max-width: 100rem;
	margin: 0 auto;
}
.ob_flow li {
	background: #F8F7F7;
	text-align: center;
	font-size: 2rem;
	letter-spacing: .05em;
	padding: 4.3rem 1rem 4.1rem;
}
.ob_flow li::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 2.4rem 1.45rem 0;
	border-color: #F8F7F7 transparent transparent;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -2.3rem;
	margin: 0 auto;
}
.ob_flow li + li {
	margin-top: 4.2rem;
}
.ob_flow .box {
	border: .2rem solid #E7380D;
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: .05em;
	border-radius: 0;
	text-align: center;
	margin-top: 4.2rem;
	color: #E7380D;
	padding: 4.1rem 1rem 3.9rem;
}
@media screen and (max-width: 767px) {
	.ob_flow {
		padding: 5rem 6.9767% 60px;
	}
	.ob_flow h2 {
		font-size: 2.6rem;
		margin-bottom: 3rem;
	}
	.ob_flow li {
		font-size: 1.6rem;
		text-align: left;
		padding: 2rem 5%;
	}
	.ob_flow li::after {
		border-width: 1.6rem 1rem 0;
		bottom: -1.5rem;
	}
	.ob_flow li + li {
		margin-top: 2rem;
	}
	.ob_flow .box {
		font-size: 1.6rem;
		margin-top: 2rem;
		padding: 2rem 5%;
	}
}

/*ob_form
----------------------------------------*/
.ob_form {
	padding: 7rem 2rem 11rem;
	color: #000;
}
.ob_form .inner {
	max-width: 100rem;
	margin: 0 auto;
}
.ob_form dl,
.contact-form-field {
	display: flex;
	flex-wrap: wrap;
}
.ob_form dl dt,
.contact-form .form-label {
	border-bottom: 2px solid #F3F3F3;
	width: 30rem;
	font-size: 1.6rem;
	letter-spacing: .1em;
	font-weight: 500;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: .8rem 0 0;
	margin-bottom: 2rem;
}
.contact-form .form-label > label {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}
.ob_form dl dt .required,
.contact-form .form-label .required {
	font-size: 1rem;
	width: 3.5rem;
	text-align: center;
	color: #fff;
	background: #E7380D;
	line-height: 1.2;
	padding: .1rem 0 .1rem .1em;
	margin-top: .4rem;
}
.ob_form dl dd,
.contact-form .form-element {
	border-bottom: 2px solid #F3F3F3;
	width: calc(100% - 30rem);
	padding: 0 0 2rem 3rem;
	margin-bottom: 2rem;
	font-weight: 500;
}
.ob_form dl dd:last-child,
.ob_form dl dt:nth-last-child(2),
.contact-form-field:nth-last-child(2) .form-label,
.contact-form-field:nth-last-child(2) .form-element {
	border-bottom: 0;
}
.ob_form dl dt:nth-last-child(2),
.contact-form-field:nth-last-child(2) .form-label,
.contact-form-field .form-label.radio {
	padding-top: 0;
	margin-top: -.2rem;
}
.ob_form dl dt:nth-last-child(2) .required,
.contact-form-field:nth-last-child(2) .form-label .required,
.contact-form-field .form-label.radio .required {
	margin-top: .7rem;
}
.ob_form dl dd:last-child,
.contact-form-field:nth-last-child(2) .form-element {
	padding-top: 0;
}
.ob_form input[type="text"],
.ob_form input[type="tel"],
.ob_form input[type="email"],
.ob_form select,
.ob_form textarea {
	width: 100%;
	appearance: none;
	background: #F3F3F3;
	border: 0;
	border-radius: .3rem;
	font-size: 1.2rem;
	height: 4.4rem;
	letter-spacing: .05em;
	font-weight: 500;
	letter-spacing: .1em;
	padding: 0 2rem;
	font-family: inherit;
}
.ob_form select {
	width: auto;
	min-width: 21.5rem;
	font-size: 1.3rem;
	background: #F3F3F3 url(../assets/icon_arrow.svg) no-repeat right 1.5rem center;
}
.ob_form textarea {
	resize: vertical;
	height: 15rem;
	padding: 1rem 2rem;
	margin-bottom: .3rem;
}
.ob_form ::placeholder {
	color: #A4A4A4;
}
.ob_form .name,
.ob_form .date,
.ob_form .sending {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
.ob_form .name p {
	width: 26.5rem;
	margin: 0;
}
.ob_form .date p {
	width: 12.6rem;
	margin: 0;
	font-size: 1.6rem;
	font-weight: 300;
}
.ob_form .sending input[type="radio"] {
	position: absolute;
	width: 0;
	height: 0;
	opacity: 0;
	visibility: hidden;
}
.ob_form .sending label {
	width: 13.5rem;
	margin: 0;
	font-size: 1.3rem;
	font-weight: 300;
	padding-left: 2.8rem;
	letter-spacing: .1em;
	position: relative;
}
.ob_form .sending label::before {
	content: '';
	display: block;
	width: 1.6rem;
	height: 1.6rem;
	background: #F3F3F3;
	position: absolute;
	top: .4rem;
	left: 0;
}
.ob_form .sending input[type="radio"]:checked + label::after {
	content: '';
	display: block;
	width: .7rem;
	height: .4rem;
	border-left: 2px solid #E7380D;
	border-bottom: 2px solid #E7380D;
	transform: rotate(-45deg);
	position: absolute;
	top: .8rem;
	left: .3rem;
}
.ob_form .name input {
	width: 18.7rem;
	margin-left: 1.5rem;
}
.ob_form .date input {
	width: 7.5rem;
	margin-right: 1.5rem;
}
.ob_form .note {
	display: block;
	font-size: 1.1rem;
	margin: .8rem 0 0 1em;
	text-indent: -1em;
	letter-spacing: .05em;
}
.privacy_policy {
	padding-top: 5.5rem;
}
.privacy_policy h2 {
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: .1em;
	margin-bottom: 1.6rem;
}
.privacy_policy h3 {
	font-size: 1.4rem;
	font-weight: 700;
	letter-spacing: .1em;
	margin-bottom: .5rem;
	margin-top: 2rem;
}
.privacy_policy h3:first-child {
	margin-top: 0;
}
.privacy_policy .inner {
	border: 1px solid #E9E9E9;
	padding: 2.2rem 1.1rem;
}
.privacy_policy .scroll {
	padding: .6rem 2rem .5rem;
	height: 15.1rem;
	scrollbar-width: thin;
	scrollbar-color: #E9E9E9 #fff;
	overflow: auto;
}
.privacy_policy .scroll::-webkit-scrollbar {
	width: .5rem;
}
.privacy_policy .scroll::-webkit-scrollbar-track {
	background: #fff;
}
.privacy_policy .scroll::-webkit-scrollbar-thumb {
	background: #E9E9E9;
}
.privacy_policy .scroll p {
	letter-spacing: .1em;
	font-weight: 300;
	line-height: 1.85;
}
.privacy_policy .scroll p + p,
.privacy_policy .scroll ol + p,
.privacy_policy .scroll ul + p {
	margin-top: 2rem;
}
.privacy_policy .scroll ol {
	letter-spacing: .1em;
	font-weight: 300;
	line-height: 1.85;
	counter-reset: ol-num;
}
.privacy_policy .scroll ol > li {
	padding-left: 1.3rem;
	text-indent: -1.4rem;
}
.privacy_policy .scroll ol > li::before {
	content: counter(ol-num, decimal) ". ";
	counter-increment: ol-num;
	margin-right: -.5rem;
}
.privacy_policy .scroll ul li {
	text-indent: -2.65rem;
	margin-left: 2.65rem;
}
.field_error {
	width: 100%;
	display: block;
	color: #E7380D;
	order: 2;
}
.btn_entry {
	display: flex;
	justify-content: space-between;
}
.btn_entry button.back,
.btn_entry button.send {
	width: 48%;
}
.btn_entry button.back {
	border-color: #aaa;
	color: #aaa;
}
.btn_entry button.back::before {
	border-color: #aaa;
	right: auto;
	left: 3.4rem;
}
.btn_entry button.back::after {
	background: #aaa;
	right: auto;
	left: 5.5rem;
}
@media screen and (max-width: 767px) {
	.ob_form {
		padding: 5rem 6.9767%;
	}
	.ob_form dl,
	.contact-form-field {
		display: block;
	}
	.ob_form dl dt,
	.contact-form .form-label {
		border-bottom: 0;
		width: auto;
		padding: 0;
		margin-bottom: .5rem;
	}
	.ob_form dl dd,
	.contact-form .form-element {
		width: auto;
		padding: 0 0 2rem;
	}
	.ob_form select {
		min-width: 100%;
		max-width: 100%;
	}
	.ob_form .name p,
	.ob_form .date p {
		width: 50%;
	}
	.ob_form .name input {
		width: 10rem;
		margin-left: 1rem;
	}
	.ob_form .date input {
		margin-right: 1rem;
	}
	.ob_form .note {
		letter-spacing: 0;
	}
	.privacy_policy {
		padding-top: 3rem;
	}
	.privacy_policy .inner {
		padding: 1rem .5rem;
	}
	.privacy_policy .scroll {
		padding: .6rem 1rem .5rem 1.5rem;
	}
	.btn_entry button.back {
		padding-left: 4rem;
	}
	.btn_entry button.send {
		padding-right: 4rem;
	}
	.btn_entry button.back::before {
		left: 1.4rem;
	}
	.btn_entry button.back::after {
		left: 2.9rem;
	}
}