@charset "UTF-8";

sup span {
	color: #008CD7;
}
.inner-content-wrap {
	position: relative;
	padding: 300px 0 0;
}
.inner-menu-wrap {
	position: absolute;
	width: 100%;
	padding: 30px 0 30px;
	margin: 0 auto;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	z-index: 5;
	background: #F5F5F5;
}
.inner-menu-wrap_fixed {
	position: fixed;
	padding: 10px 0 5px;
	top: 65px;
	left: 50%;
	transform: translateX(-50%);
}
.innter-menu-box {
	position: relative;
	width: 90%;
	margin: 0 auto;
	max-width: 1120px;
}
.innter-menu-box > p {
	position: relative;
	text-align: center;
	color: var(--main-color);
	font-family: var(--en-font);
	font-size: 20px;
	font-weight: 700;
	padding-bottom: 10px;
}
.inner-menu-wrap_fixed .innter-menu-box > p {
	font-size: 18px;
	padding-bottom: 1px;
}
.innter-menu-box ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.innter-menu-box ul li {
	width: 33.0%;
	margin-bottom: 5px;
	position: relative;
	box-sizing: border-box;
	cursor: pointer;
	background: #FFF;
	padding: 10px;
	min-height: 30px;
	transition: all .5s;
	filter: drop-shadow(0px 0px 3px rgba(191, 199, 211, 0.5));
}
.inner-menu-wrap_fixed .innter-menu-box ul li {
	padding: 5px 10px;
	min-height: 24px;
}
.innter-menu-box ul li p {
	position: relative;
	padding-left: 30px;
	font-size: 12px;
	line-height: 1.4em;
	top: 50%;
	transform: translateY(-50%);
}
.innter-menu-box ul li p span {
	color: var(--main-color);
	font-family: var(--en-font);
	font-size: 16px;
	font-weight: 700;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
.special main > .content-wrap {
	position: relative;
}
.special main > .content-wrap:before {
	position: absolute;
	background-image: url("https://www.proterial.com/rcrt/assets/img/common_img/triangle01.svg");
	background-position: left top;
	right: 15vw;
	top: 220px;
	width: calc(1024px * 2);
	height: calc(890px * 2);
	z-index: -2;
}
.special-main {
	position: relative;
	width: 90%;
	max-width: 1240px;
	margin: 0 auto;
}
.special-main .white-box {
	position: relative;
	background: #FFF;
	width: 80%;
	max-width: 440px;
	box-sizing: border-box;
	padding: 30px;
	left: 50px;
	bottom: 50px;
	margin-bottom: -50px;
}
.special-main .white-box p {
	font-size: 40px;
	font-weight: 600;
	line-height: 1.4em;
}
.future .special-main {
	padding-bottom: 120px;
}
.future .profile-box {
	position: relative;
	left: 60%;
	top: -140px;
	margin-bottom: -140px;
}
.future .profile-box p:nth-child(1) {
	font-size: 22px;
	font-weight: 600;
	padding-bottom: 5px;
}
.future .profile-box p:nth-child(1) span {
	color: var(--main-color);
	font-family: var(--en-font);
}
.future .section-ttl {
	width: calc(100% - 160px);
	margin: 0 auto 20px;
	max-width: 1120px;
	color: var(--main-color);
	font-size: 24px;
	position: relative;
}
.future .section-ttl span {
	color: var(--main-color);
	font-family: var(--en-font);
	font-size: 70px;
	font-weight: 700;
	line-height: 1em;
	padding-right: 20px;
}
.future div[class^="article0"] {
	width: calc(100% - 160px);
	margin: 0 auto 40px;
	max-width: 1120px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
	padding: 0 0 100px;
}
.future .article01 .txt {
	width: 48%;
}
.future .article01 .vis {
	width: 48vw;
	left: 53%;
	position: absolute;
	max-width: 650px;
}
.future .article04 {
	margin-bottom: 100px;
}
.future .article04 .txt {
	width: 48%;
	left: 53%;
	position: relative;
}
.future .article04 .vis {
	width: 48vw;
	left: 48%;
	transform: translateX(-101%);
	position: absolute;
	max-width: 650px;
}
@media screen and (max-width: 767px) {
	.inner-content-wrap {
		position: relative;
		padding: 0 0 0;
	}
	.inner-menu-wrap {
		position: relative;
		width: 100%;
		padding: 30px 0 30px;
		margin: 0 auto 50px;
		top: 0;
		left: 50%;
		transform: translateX(-50%);
		z-index: 5;
		background: #F5F5F5;
	}
	.inner-menu-wrap_fixed {
		position: absolute;
		padding: 10px 0 5px;
		top: 65px;
		left: 50%;
		transform: translateX(-50%);
	}
	.innter-menu-box {
		position: relative;
		width: 90%;
		margin: 0 auto;
		max-width: 1120px;
	}
	.innter-menu-box > p {
		position: relative;
		text-align: center;
		color: var(--main-color);
		font-family: var(--en-font);
		font-size: 20px;
		font-weight: 700;
	}
	.innter-menu-box ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.innter-menu-box ul li {
		width: 49.7%;
		margin-bottom: 5px;
		position: relative;
		cursor: pointer;
		background: #FFF;
		padding: 10px;
		min-height: 30px;
		transition: all .5s;
	}
	.inner-menu-wrap_fixed .innter-menu-box ul li {
		padding: 5px 10px;
		min-height: 24px;
	}
	.innter-menu-box ul li p {
		position: relative;
		padding-left: 30px;
		font-size: 12px;
		line-height: 1.4em;
		top: 50%;
		transform: translateY(-50%);
	}
	.innter-menu-box ul li p span {
		color: var(--main-color);
		font-family: var(--en-font);
		font-size: 16px;
		font-weight: 700;
		position: absolute;
		left: 0;
		top: 50%;
		transform: translateY(-50%);
	}
	.special main > .content-wrap {
		position: relative;
	}
	.special main > .content-wrap:before {
		position: absolute;
		background-image: url("https://www.proterial.com/rcrt/assets/img/common_img/triangle01.svg");
		background-position: left top;
		right: 15vw;
		top: 50px;
		width: calc(1024px * 2);
		height: calc(890px * 2);
		z-index: -2;
	}
	.special-main {
		position: relative;
		width: 96%;
		max-width: 1240px;
		margin: 0 auto;
	}
	.special-main .white-box {
		position: relative;
		background: #FFF;
		width: 80%;
		max-width: 300px;
		box-sizing: border-box;
		padding: 15px;
		left: 10px;
		bottom: 10px;
		margin-bottom: -20px;
	}
	.special-main .white-box p {
		font-size: min(5vw,30px);
		font-weight: 600;
		line-height: 1.4em;
	}
	.future .special-main {
		padding-bottom: 120px;
	}
	.future .profile-box {
		position: relative;
		left: 20px;
		top: 20px;
		margin-bottom: -50px;
	}
	.future .profile-box p:nth-child(1) {
		font-size: 18px;
		font-weight: 600;
		padding-bottom: 5px;
	}
	.future .profile-box p:nth-child(1) span {
		font-size: 14px;
		color: var(--main-color);
		font-family: var(--en-font);
	}
	.future .profile-box p:nth-child(2) {
		font-size: 11px;
	}
	.future .section-ttl {
		width: calc(90%);
		margin: 0 auto 10px;
		max-width: 1120px;
		color: var(--main-color);
		font-size: 18px;
		position: relative;
	}
	.future .section-ttl span {
		color: var(--main-color);
		font-family: var(--en-font);
		font-size: 30px;
		font-weight: 700;
		line-height: 1em;
		padding-right: 10px;
	}
	.future div[class^="article0"] {
		width: 90%;
		margin: 0 auto 30px;
		max-width: 1120px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		padding: 0 0 30px;
	}
	.future .article01 .txt {
		width: 100%;
		padding: 0 0 40px;
	}
	.future .article01 .vis {
		width: 100%;
		left: 0;
		position: relative;
	}
	.future .article04 {
		margin-bottom: 0px;
	}
	.future .article04 .txt {
		width: 100%;
		left: 0;
		padding: 0 0 40px;
	}
	.future .article04 .vis {
		width: 100%;
		left: 0;
		transform: translateX(0);
		position: relative;
		max-width: 650px;
	}
}
@media screen and (max-width: 480px) {
	.future .section-ttl {
		width: calc(90%);
		box-sizing: border-box;
		margin: 0 auto 10px;
		max-width: 1120px;
		color: var(--main-color);
		font-size: 16px;
		position: relative;
		padding-left: 40px;
		line-height: 1.4em;
	}
	.future .section-ttl span {
		color: var(--main-color);
		font-family: var(--en-font);
		font-size: 30px;
		font-weight: 700;
		line-height: 1em;
		padding-right: 10px;
		position: absolute;
		left: 0;
		top: -5px;
	}
	.innter-menu-box ul li {
		width: 100%;
		margin-bottom: 5px;
		position: relative;
		cursor: pointer;
		background: #FFF;
		padding: 6px;
		min-height: 30px;
		transition: all .5s;
	}
}


.talk-member {
	padding: 80px 0;
}
.talk-member .content > p,
.after-talk {
	position: relative;
	text-align: center;
	color: var(--main-color);
	font-family: var(--en-font);
	font-size: 20px;
	font-weight: 700;
	margin-bottom: 20px;
}
.talk-member .content ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.talk-member .content ul li {
	width: 48%;
	margin: 0 0 30px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.talk-member .content ul li .image {
	width: 48%;
}
.talk-member .content ul li .txt {
	width: 48%;
}
.talk-member .content ul li .txt > p:nth-of-type(1) {
	font-family: var(--en-font);
	font-size: 42px;
	font-weight: 700;
	line-height: 1.4em;
}
.talk-member .content ul li .txt > p:nth-of-type(2) {
	font-size: 12px;
	line-height: 1.4em;
	padding-bottom: 10px;
}
.talk-member .content ul li .txt > p:nth-of-type(3){
	color: #025A8A;
	font-size: 12px;
	line-height: 1.4em;
}
.talk-member .content ul li .txt > p:nth-of-type(3) span {
	display: inline-block;
	margin-right: 6px;
	margin-bottom: 10px;
	padding: 2px 5px;
	background: #025A8A;
	color: #FFF;
}
.talk-member .content ul li .txt .more-profile p {
	color: #008CD7;
	font-size: 14px;
}
.talk-section04 {
	background: #F5F5F5;
	padding: 60px 0 0;
	margin-bottom: 100px;
}
.diversity .insert01 {
	padding: 30px 0 60px;
}
.diversity div[class^="talk-block0"] {
	width: calc(100% - 160px);
	margin: 0 auto 40px;
	max-width: 1120px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	position: relative;
	padding: 0 0 60px;
}
.diversity .section-ttl {
	width: calc(100% - 160px);
	margin: 0 auto 10px;
	max-width: 1120px;
	box-sizing: border-box;
	position: relative;
	height: 40px;
}
.diversity .section-ttl span {
	font-size: 40px;
	font-weight: 700;
	letter-spacing: 0.09em;
	font-family: var(--en-font);
	color: var(--main-color);
	display: inline-block;
	background: #FFF;
	padding-right: 15px;
	line-height: 40px;
}
.diversity .section-ttl:after {
	width: 100vw;
	height: 2px;
	background: var(--main-color);
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	z-index: -2;
}
.diversity .section-theme {
	width: calc(100% - 160px);
	margin: 0 auto 40px;
	max-width: 1120px;
	box-sizing: border-box;
	font-size: min(5vw,32px);
	font-weight: 700;
	line-height: 1.5em;
}
.diversity .section-theme span {
	color: var(--main-color);
}
.diversity .talk-block02 .txt {
	width: 48%;
}
.diversity .talk-block02 .vis {
	width: 48vw;
	left: 53%;
	position: absolute;
	max-width: 650px;
}
.diversity .talk-block03 {
	margin-bottom: 100px;
}
.diversity .talk-block03 .txt {
	width: 48%;
	left: 53%;
	position: relative;
}
.diversity .talk-block03 .vis {
	width: 48vw;
	left: 48%;
	transform: translateX(-101%);
	position: absolute;
	max-width: 650px;
}

.diversity p[class^="spk0"] {
	padding-left: 65px;
	min-height: 65px;
	margin-bottom: 1.4em;
	position: relative;
}
.diversity p[class^="spk0"]:before {
	width: 48px;
	height: 48px;
	left: 0;
	top: -5px;
}
.diversity p[class^="spk0"]:after {
	width: 48px;
	left: 0;
	top: 42px;
	font-size: 11px;
	font-family: var(--en-font);
	font-weight: 700;
	text-align: center;
}
.diversity .spk01:before {
	background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/diversity_member01.jpg");
}
.diversity .spk01:after {
	content: "T.K.";
}
.diversity .spk02:before {
	background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/diversity_member02.jpg");
}
.diversity .spk02:after {
	content: "X.T.";
}
.diversity .spk03:before {
	background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/diversity_member03.jpg");
}
.diversity .spk03:after {
	content: "O.M.";
}
.diversity .spk04:before {
	background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/diversity_member04.jpg");
}
.diversity .spk04:after {
	content: "A.K.";
}

@media screen and (max-width: 767px) {
	.talk-member {
		padding: 40px 0;
	}
	.talk-member .content > p,
	.after-talk {
		position: relative;
		text-align: center;
		color: var(--main-color);
		font-family: var(--en-font);
		font-size: 18px;
		font-weight: 700;
		margin-bottom: 20px;
	}
	.talk-member .content ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.talk-member .content ul li {
		width: 48%;
		margin: 0 0 30px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.talk-member .content ul li .image {
		width: 30%;
	}
	.talk-member .content ul li .txt {
		width: 66%;
	}
	.talk-member .content ul li .txt > p:nth-of-type(1) {
		font-family: var(--en-font);
		font-size: 26px;
		font-weight: 700;
		line-height: 1.4em;
	}
	.talk-member .content ul li .txt > p:nth-of-type(2) {
		font-size: 12px;
		line-height: 1.4em;
		padding-bottom: 10px;
	}
	.talk-member .content ul li .txt > p:nth-of-type(3){
		color: #025A8A;
		font-size: 12px;
		line-height: 1.4em;
	}
	.talk-member .content ul li .txt > p:nth-of-type(3) span {
		display: inline-block;
		margin-right: 6px;
		margin-bottom: 10px;
		padding: 2px 5px;
		background: #025A8A;
		color: #FFF;
	}
	.talk-member .content ul li .txt .more-profile p {
		color: #008CD7;
		font-size: 12px;
	}
	.talk-section04 {
		background: #F5F5F5;
		padding: 30px 0 0;
		margin-bottom: 50px;
	}
	.diversity .insert01 {
		padding: 30px 0 60px;
	}
	.diversity div[class^="talk-block0"] {
		width: calc(90%);
		margin: 0 auto 20px;
		max-width: 1120px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		padding: 0 0 30px;
	}
	.diversity .section-ttl {
		width: calc(90%);
		margin: 0 auto;
		max-width: 1120px;
		box-sizing: border-box;
		position: relative;
		height: 40px;
	}
	.diversity .section-ttl span {
		font-size: 20px;
		font-weight: 700;
		letter-spacing: 0.09em;
		font-family: var(--en-font);
		color: var(--main-color);
		display: inline-block;
		background: #FFF;
		padding-right: 10px;
		line-height: 40px;
	}
	.diversity .section-ttl:after {
		width: 100vw;
		height: 1px;
		background: var(--main-color);
		top: 50%;
		transform: translateY(-50%);
		left: 0;
		z-index: -2;
	}
	.diversity .section-theme {
		width: calc(90%);
		margin: 0 auto 40px;
		max-width: 1120px;
		box-sizing: border-box;
		font-size: min(4vw,22px);
		font-weight: 700;
		line-height: 1.5em;
	}
	.diversity .section-theme span {
		color: var(--main-color);
	}
	.diversity .talk-block02 .txt {
		width: 100%;
	}
	.diversity .talk-block02 .vis {
		width: 80%;
		left: 0;
		margin: 0 auto;
		position: relative;
		max-width: 650px;
	}
	.diversity .talk-block03 {
		margin-bottom: 100px;
	}
	.diversity .talk-block03 .txt {
		width: 100%;
		left: 0;
		position: relative;
	}
	.diversity .talk-block03 .vis {
		width: 80%;
		left: 0;
		transform: translateX(0);
		margin: 0 auto;
		position: relative;
		max-width: 650px;
	}

	.diversity p[class^="spk0"] {
		padding-left: 65px;
		min-height: 65px;
		margin-bottom: 1.4em;
		position: relative;
	}
	.diversity p[class^="spk0"]:before {
		width: 48px;
		height: 48px;
		left: 0;
		top: -5px;
	}
	.diversity p[class^="spk0"]:after {
		width: 48px;
		left: 0;
		top: 42px;
		font-size: 11px;
		font-family: var(--en-font);
		font-weight: 700;
		text-align: center;
	}
}

@media screen and (max-width: 480px) {
	.talk-member .content ul li {
		width: 100%;
		margin: 0 0 15px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.talk-member .content ul li .image {
		width: 70px;
	}
	.talk-member .content ul li .txt {
		width: calc(100% - 80px);
	}
	.talk-member .content ul li .txt > p:nth-of-type(1) {
		font-family: var(--en-font);
		font-size: 18px;
		font-weight: 700;
		line-height: 1.4em;
	}
	.talk-member .content ul li .txt > p:nth-of-type(2) {
		font-size: 12px;
		line-height: 1.4em;
		padding-bottom: 5px;
	}
	.talk-member .content ul li .txt > p:nth-of-type(3){
		color: #025A8A;
		font-size: 11px;
		line-height: 1.4em;
	}
	.talk-member .content ul li .txt > p:nth-of-type(3) span {
		display: inline-block;
		margin-right: 6px;
		margin-bottom: 10px;
		padding: 2px 5px;
		background: #025A8A;
		color: #FFF;
	}
	.talk-member .content ul li .txt .more-profile p {
		color: #008CD7;
		font-size: 12px;
	}
	.talk-member .content ul li .txt .more-profile {
		position: relative;
		width: 90vw;
		left: 100%;
		transform: translateX(-100%);
	}
	.talk-member .content ul li .txt .more-profile .toggle-box {
		
	}
}

.toggle-btn {
	display: none;
}

@media screen and (max-width: 480px) {
	.talk-member .content ul li .txt .more-profile {
		display: flex;
		flex-wrap: wrap;
	}
	.toggle-btn {
		display: block;
		position: relative;
		width: 100%;
		order: 2;
	}
	.toggle-btn:before {
		display: block;
		content: "プロフィール詳細をみる";
		position: relative;
		width: 60%;
		left: 50%;
		transform: translateX(-50%);
		height: 20px;
		background: #FFF;
		color: var(--main-color);
		font-size: 11px;
		line-height: 20px;
		text-align: center;
		border-radius: 10px;
		filter: drop-shadow(0px 0px 3px rgba(191, 199, 211, 0.5));
	}
	.toggle-btn.on:before {
		content: "閉じる"
	}
	.toggle-box {
		display: none;
		width: 100%;
		padding: 0 0 10px;
		order: 1;
	}
}

















.special-ex .inner-block {
	margin-bottom: 80px;
}
.special-ex .main-block {
	width: calc(100% - 160px);
	margin: 0 auto 40px;
	max-width: 1120px;
	position: relative;
	padding: 0 0 60px;
}
.special-ex .section-ttl {
	width: calc(100%);
	margin: 0 auto 20px;
	max-width: 1120px;
	box-sizing: border-box;
	position: relative;
	height: 40px;
}
.special-ex .section-ttl span {
	font-size: 40px;
	font-weight: 700;
	letter-spacing: 0.09em;
	font-family: var(--en-font);
	color: var(--main-color);
	display: inline-block;
	background: #FFF;
	padding-right: 15px;
	line-height: 40px;
}
.special-ex .section-ttl:after {
	width: 100vw;
	height: 2px;
	background: var(--main-color);
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	z-index: -2;
}
.special-ex .block-ttl {
	font-size: 24px;
	color: var(--main-color);
	vertical-align: middle;
	margin-bottom: 30px;
}
.special-ex .block-ttl span {
	font-size: 80px;
	font-weight: 600;
	font-family: var(--en-font);
	color: var(--main-color);
	vertical-align: middle;
	padding-right: 15px;
}
.special-ex .section-theme {
	width: calc(100%);
	margin: 0 auto 30px;
	max-width: 1120px;
	box-sizing: border-box;
	font-size: min(5vw, 32px);
	font-weight: 700;
	line-height: 1.5em;
}
.special-ex .section-theme span {
	color: var(--main-color);
}
.sp-split {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.sp-split .txt {
	width: 48%;
}
.sp-split .txt .note {
	color: var(--main-color);
	font-size: 70%;
	padding: 10px 0 0;
}
.sp-split .image {
	width: 48%;
}
.sp-split.flip {
	padding: 40px 0 0;
}
.sp-split.flip .txt {
	order: 2;
}
.sp-split.flip .image {
	order: 1;
}
.special-main02 {
	position: relative;
	width: 90%;
	max-width: 1240px;
	margin: 0 auto 80px;
}
.special-main02 .ttl-box {
	position: absolute;
	top: 50%;
	left: 50%;
	display: inline-block;
	transform: translate(-50%, -50%);
	z-index: 2;
}
.special-main02 .ttl-box .bdr-ttl {
	position: relative;
	width: 100%;
	margin-bottom: 20px;
}
.special-main02 .ttl-box .bdr-ttl span {
	display: inline-block;
	position: relative;
	font-size: 14px;
	padding: 0 6px;
	font-weight: 600;
	color: #001E50;
	border: solid 2px #001E50;
	background: #FFF;
	left: 50%;
	transform: translateX(-50%);
}
.special-main02 .ttl-box .ttl {
	text-align: center;
	color: #FFF;
	font-size: 40px;
	font-weight: 600;
	line-height: 1.6em;
	white-space: nowrap;
}
.special .next-arrow {
	padding-bottom: 30px;
	margin-bottom: 60px;
	position: relative;
}
.special .next-arrow:after {
	width: 160px;
	height: 30px;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	background-image: url("https://www.proterial.com/rcrt/assets/img/common_img/down-arrow.svg")
}
.env-intro {
	position: relative;
}
.env-intro > p {
	text-align: center;
	font-size: 20px;
	font-weight: 600;
}
.three-topics {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.three-topics li {
	width: 30.33%;
	margin: 30px auto;
}
.three-topics li .txt {
	padding: 20px 20px 0;
}
.our-topics {
	position: relative;
}
.our-topics .content-logo {
	text-align: center;
}
.our-topics .content-logo img {
	width: 80%;
	max-width: 350px;
	text-align: center;
}
.our-topics .content-logo p {
	text-align: center;
	font-size: 20px;
	font-weight: 600;
	padding: 20px 0;
}
.our-topics ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 50px;
}
.our-topics ul li {
	width: 49%;
	box-sizing: border-box;
	position: relative;
	background: #FFF;
	padding: 40px 30px 30px;
	transition: all .5s;
	filter: drop-shadow(0px 0px 3px rgba(191, 199, 211, 0.5));
}
.our-topics ul li .ttl {
	text-align: center;
	font-weight: 600;
	font-size: 20px;
	padding-bottom: 5px;
}
.g-enabler {
	margin-bottom: 120px;
}
.g-enabler > .ttl {
	text-align: center;
}
.g-enabler > .ttl img {
	width: 80%;
	max-width: 520px;
	text-align: center;
}
.g-enabler > .ttl p {
	text-align: center;
	font-size: 20px;
	font-weight: 600;
	padding: 20px 0 0;
}
.special-ex .figure-full {
	margin: 40px 0;
}

@media screen and (max-width: 767px) {
	.special-ex .inner-block {
		margin-bottom: 60px;
	}
	.special-ex .main-block {
		width: 90%;
		margin: 0 auto 30px;
		padding: 0 0 30px;
	}
	.special-ex .section-ttl {
		width: calc(100%);
		margin: 0 auto 0px;
		height: 40px;
	}
	.special-ex .section-ttl span {
		font-size: 20px;
		font-weight: 700;
		letter-spacing: 0.09em;
		padding-right: 10px;
		line-height: 40px;
	}
	.special-ex .section-ttl:after {
		width: 100vw;
		height: 1px;
	}
	.special-ex .block-ttl {
		font-size: 18px;
		color: var(--main-color);
		vertical-align: middle;
		margin-bottom: 10px;
		padding-left: 34px;
	}
	.special-ex .block-ttl span {
		position: absolute;
		left: 0;
		top: 0;
		font-size: 30px;
		font-weight: 600;
		font-family: var(--en-font);
		color: var(--main-color);
		vertical-align: middle;
		padding-right: 15px;
	}
	.special-ex .section-theme {
		width: calc(100%);
		margin: 0 auto 10px;
		max-width: 1120px;
		box-sizing: border-box;
		font-size: min(5vw, 32px);
		font-weight: 700;
		line-height: 1.5em;
	}
	.special-ex .section-theme span {
		color: var(--main-color);
	}
	.sp-split {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.sp-split .txt {
		width: 100%;
		padding-bottom: 20px;
	}
	.sp-split .txt .note {
		color: var(--main-color);
		font-size: 70%;
		padding: 10px 0 0;
	}
	.sp-split .image {
		width: 100%;
	}
	.sp-split.flip {
		padding: 20px 0 0;
	}
	.sp-split.flip .txt {
		order: 1;
	}
	.sp-split.flip .image {
		order: 2;
	}
	.special-main02 {
		position: relative;
		width: 90%;
		max-width: 1240px;
		margin: 0 auto 40px;
	}
	.special-main02 .main-visual img {
		object-fit: cover;
		min-height: 250px;
	}
	.special-main02 .ttl-box {
		position: absolute;
		top: 50%;
		left: 50%;
		display: inline-block;
		transform: translate(-50%, -50%);
		z-index: 2;
	}
	.special-main02 .ttl-box .bdr-ttl {
		position: relative;
		width: 100%;
		margin-bottom: 20px;
	}
	.special-main02 .ttl-box .bdr-ttl span {
		display: inline-block;
		white-space: nowrap;
		position: relative;
		font-size: 11px;
		padding: 6px 6px;
		font-weight: 600;
		line-height: 1.3em;
		text-align: center;
		color: #001E50;
		border: solid 2px #001E50;
		background: #FFF;
		left: 50%;
		transform: translateX(-50%);
	}
	.special-main02 .ttl-box .ttl {
		text-align: center;
		color: #FFF;
		font-size: 18px;
		font-weight: 600;
		line-height: 1.6em;
		white-space: nowrap;
	}
	.special .next-arrow {
		padding-bottom: 20px;
		margin-bottom: 40px;
		position: relative;
	}
	.special .next-arrow:after {
		width: calc(160px * .6);
		height: calc(30px * .6);
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		background-image: url("https://www.proterial.com/rcrt/assets/img/common_img/down-arrow.svg")
	}
	.env-intro {
		position: relative;
	}
	.env-intro > p {
		text-align: center;
		font-size: 20px;
		font-weight: 600;
	}
	.three-topics {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		position: relative;
		width: 90%;
		max-width: 300px;
		margin: 20px auto 0;
	}
	.three-topics li {
		width: 100%;
		margin: 0 0 20px;
	}
	.three-topics li .txt {
		padding: 20px 10px 0;
	}
	.our-topics {
		position: relative;
	}
	.our-topics .content-logo {
		text-align: center;
	}
	.our-topics .content-logo img {
		width: 80%;
		max-width: 200px;
		text-align: center;
	}
	.our-topics .content-logo p {
		text-align: center;
		font-size: 16px;
		font-weight: 600;
		padding: 10px 0;
	}
	.our-topics ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin-bottom: 30px;
	}
	.our-topics ul li {
		width: 100%;
		box-sizing: border-box;
		position: relative;
		background: #FFF;
		padding: 20px 20px 20px;
		transition: all .5s;
		filter: drop-shadow(0px 0px 3px rgba(191, 199, 211, 0.5));
		margin-bottom: 20px;
	}
	.our-topics ul li .ttl {
		text-align: center;
		font-weight: 600;
		font-size: 16px;
		padding-bottom: 5px;
	}
	.g-enabler {
		margin-bottom: 40px;
	}
	.g-enabler > .ttl {
		text-align: center;
	}
	.g-enabler > .ttl img {
		width: 80%;
		max-width: 520px;
		text-align: center;
	}
	.g-enabler > .ttl p {
		text-align: center;
		font-size: 20px;
		font-weight: 600;
		padding: 10px 0 0;
	}
	.special-ex .figure-full {
		margin: 30px 0;
		padding-bottom: 40px;
	}
}


.qua-intro {
	position: relative;
}
.qua-intro p {
	text-align: center;
	line-height: 1.6em;
}
.qua-intro p:nth-of-type(1) {
	font-weight: 600;
	font-family: var(--en-font);
	font-size: 48px;
}
.qua-intro p:nth-of-type(2) {
	font-size: 20px;
	font-weight: 600;
	padding-bottom: 30px;
}
.qua-intro p:nth-of-type(3) {
	font-size: 54px;
	font-weight: 600;
}
.qua-intro p:nth-of-type(4) {
	font-size: 20px;
	font-weight: 600;
	padding-bottom: 50px;
}
.quality .figure01 {
	width: 90%;
	margin: 0 auto 60px;
	max-width: 740px;
}
.relation-detail {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 60px auto;
}
.relation-detail .image {
	width: 30%;
}
.relation-detail .txt {
	width: 66%;
	box-sizing: border-box;
	padding: 5% 0 0;
}
.relation-detail .txt > p {
	font-weight: 600;
}
.dot-list-red {
	position: relative;
	margin: 20px 0 0;
	padding-right: 15%;
}
.dot-list-red li {
	font-size: 14px;
	position: relative;
	margin-bottom: 10px;
	padding-left: 15px;
}
.dot-list-red li:before {
	width: 8px;
	height: 8px;
	background: #DC4051;
	left: 0;
	top: 9px;
}
@media screen and (max-width: 767px) {
	.quality .main-visual img {
		object-position: 80% center;
	}
	.qua-intro {
		position: relative;
	}
	.qua-intro p {
		text-align: center;
		line-height: 1.6em;
	}
	.qua-intro p:nth-of-type(1) {
		font-weight: 600;
		font-family: var(--en-font);
		font-size: 28px;
	}
	.qua-intro p:nth-of-type(2) {
		font-size: 16px;
		font-weight: 600;
		padding-bottom: 20px;
	}
	.qua-intro p:nth-of-type(3) {
		font-size: 30px;
		font-weight: 600;
	}
	.qua-intro p:nth-of-type(4) {
		font-size: 16px;
		font-weight: 600;
		padding-bottom: 30px;
	}
	.quality .figure01 {
		width: 100%;
		margin: 0 auto 30px;
		max-width: 740px;
	}
	.relation-detail {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 40px auto;
	}
	.relation-detail .image {
		width: 100%;
		max-width: 180px;
		margin: 0 auto;
	}
	.relation-detail .txt {
		width: 100%;
		box-sizing: border-box;
		padding: 5% 0 0;
	}
	.relation-detail .txt > p {
		font-weight: 600;
	}
	.dot-list-red {
		position: relative;
		margin: 20px 0 0;
		padding-right: 0;
	}
	.dot-list-red li {
		font-size: 12px;
		position: relative;
		margin-bottom: 10px;
		padding-left: 15px;
	}
	.dot-list-red li:before {
		width: 8px;
		height: 8px;
		background: #DC4051;
		left: 0;
		top: 9px;
	}
}


.abi-intro {
	position: relative;
}
.abi-intro p {
	text-align: center;
	line-height: 1.6em;
}
.abi-intro p:nth-of-type(1) {
	font-weight: 600;
	font-size: 20px;
	padding-bottom: 10px;
}
.abi-intro p:nth-of-type(2) {
	font-weight: 600;
	font-size: 32px;
	padding-bottom: 50px;
}
.abi-ideal {
	position: relative;
	margin-bottom: 60px;
}
.abi-ideal > p:nth-of-type(1) {
	font-weight: 600;
	text-align: center;
	font-size: 20px;
	margin-bottom: 20px;
}
.abi-ideal .ideal-list-ttl {
	width: 100%;
	box-sizing: border-box;
	padding: 25px 5%;
	background: #001E50;
	margin-bottom: 30px;
}
.abi-ideal .ideal-list-ttl p {
	font-weight: 600;
	font-size: 20px;
	text-align: center;
	color: #FFF;
	padding-bottom: 0;
	margin-bottom: 0;
}
.abi-ideal ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.abi-ideal ul li {
	width: 48.5%;
	margin-bottom: 3%;
	box-sizing: border-box;
	position: relative;
	padding: 30px;
	background: #F5F5F5;
}
.abi-ideal ul li p {
	color: #025A8A;
}
.abi-ideal ul li p:nth-of-type(1) {
	font-size: 18px;
	font-weight: 600;
}
.abi-ideal ul li p:nth-of-type(2) {
	font-size: 14px;
}
.abi-ideal ul + p {
	text-align: center;
	font-size: 20px;
	font-weight: 600;
	padding-bottom: 10px;
}
.abi-ideal a {
	color: #008CD7;
	text-decoration: underline;
}
.sub-ttl {
	font-size: 32px;
	font-weight: 600;
}
.sub-ttl span {
	color: var(--main-color);
}
.flow-schedule {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 30px 0 0;
}
.flow-schedule dt {
	width: 90px;
	min-height: 90px;
	margin-bottom: 50px;
	position: relative;
	background: url("https://www.proterial.com/rcrt/assets/img/special_img/special-abi-calender.png") no-repeat center center;
	background-size: 90px auto;
}
.flow-schedule dt:after {
	width: 26px;
	height: 16px;
	background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/red-arrow.svg");
	left: 50%;
	bottom: -35px;
	transform: translateX(-50%);
}
.flow-schedule dt:last-of-type:after {
	display: none;
}
.flow-schedule dt p {
	position: relative;
	text-align: center;
	top: 50%;
	transform: translateY(-50%);
	font-weight: 600;
	font-size: 26px;
}
.flow-schedule dt p span {
	font-size: 16px;
}
.flow-schedule dd {
	width: calc(100% - 120px);
	box-sizing: border-box;
	padding: 12px 0 0;
}
.flow-schedule dd p:nth-of-type(1) {
	font-size: 22px;
	line-height: 1.4em;
	color: #008CD7;
	font-weight: 600;
	padding-bottom: 5px;
}
.flow-schedule dd p:nth-of-type(2) {
	line-height: 1.6em;
}
.flow-schedule dd p:nth-of-type(2) span {
	font-size: 12px;
	display: block;
}

@media screen and (max-width: 767px) {
	.abi-intro {
		position: relative;
	}
	.abi-intro p {
		text-align: center;
		line-height: 1.6em;
	}
	.abi-intro p:nth-of-type(1) {
		font-weight: 600;
		font-size: 15px;
		padding-bottom: 10px;
	}
	.abi-intro p:nth-of-type(2) {
		font-weight: 600;
		font-size: 18px;
		padding-bottom: 30px;
	}
	.abi-ideal {
		position: relative;
		margin-bottom: 30px;
	}
	.abi-ideal > p:nth-of-type(1) {
		font-weight: 600;
		text-align: center;
		font-size: 15px;
		margin-bottom: 10px;
	}
	.abi-ideal .ideal-list-ttl {
		width: 100%;
		box-sizing: border-box;
		padding: 20px 5%;
		background: #001E50;
		margin-bottom: 30px;
	}
	.abi-ideal .ideal-list-ttl p {
		font-weight: 600;
		font-size: 16px;
		text-align: center;
		color: #FFF;
		padding-bottom: 0;
		margin-bottom: 0;
	}
	.abi-ideal ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin-bottom: 30px;
	}
	.abi-ideal ul li {
		width: 100%;
		margin-bottom: 3%;
		box-sizing: border-box;
		position: relative;
		padding: 20px;
		background: #F5F5F5;
	}
	.abi-ideal ul li p {
		color: #025A8A;
	}
	.abi-ideal ul li p:nth-of-type(1) {
		font-size: 15px;
		font-weight: 600;
	}
	.abi-ideal ul li p:nth-of-type(2) {
		font-size: 13px;
	}
	.abi-ideal ul + p {
		text-align: center;
		font-size: 15px;
		font-weight: 600;
		padding-bottom: 10px;
	}
	p .blue-line {
		color: #008CD7;
		text-decoration: underline;
	}
	.sub-ttl {
		font-size: 20px;
		font-weight: 600;
	}
	.sub-ttl span {
		color: var(--main-color);
	}
	.flow-schedule {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin: 20px 0 0;
	}
	.flow-schedule dt {
		width: 50px;
		min-height: 50px;
		margin-bottom: 50px;
		position: relative;
		background: url("https://www.proterial.com/rcrt/assets/img/special_img/special-abi-calender.png") no-repeat center top;
		background-size: 50px auto;
	}
	.flow-schedule dt:after {
		width: calc(26px * .6);
		height: calc(16px * .6);
		background-image: url("https://www.proterial.com/rcrt/assets/img/special_img/red-arrow.svg");
		left: 50%;
		bottom: auto;
		top: 60px;
		transform: translateX(-50%);
	}
	.flow-schedule dt:last-of-type:after {
		display: none;
	}
	.flow-schedule dt p {
		position: relative;
		text-align: center;
		top: 10px;
		transform: translateY(0);
		font-weight: 600;
		font-size: 15px;
	}
	.flow-schedule dt p span {
		font-size: 11px;
	}
	.flow-schedule dd {
		width: calc(100% - 60px);
		box-sizing: border-box;
		padding: 5px 0 0;
	}
	.flow-schedule dd p:nth-of-type(1) {
		font-size: 15px;
		line-height: 1.4em;
		color: #008CD7;
		font-weight: 600;
		padding-bottom: 5px;
	}
	.flow-schedule dd p:nth-of-type(2) {
		line-height: 1.6em;
		font-size: 13px;
	}
	.flow-schedule dd p:nth-of-type(2) span {
		font-size: 11px;
		display: block;
	}
}