@charset "utf-8";
@font-face {
	font-family: "Zen Kaku Gothic New";
	font-weight: 400;
	font-style: normal;
	src: url(fonts/zenkakugothicnew-regular.ttf);
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	font-weight: 500;
	font-style: normal;
	src: url(fonts/zenkakugothicnew-medium.ttf);
}
@font-face {
	font-family: "Zen Kaku Gothic New";
	font-weight: 700;
	font-style: normal;
	src: url(fonts/zenkakugothicnew-bold.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 200;
	font-style: normal;
	src: url(fonts/mulish-extralight.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 400;
	font-style: normal;
	src: url(fonts/mulish-regular.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 400;
	font-style: italic;
	src: url(fonts/mulish-italic.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 500;
	font-style: normal;
	src: url(fonts/mulish-medium.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 500;
	font-style: italic;
	src: url(fonts/mulish-mediumitalic.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 600;
	font-style: normal;
	src: url(fonts/mulish-semibold.ttf);
}
@font-face {
	font-family: "Mulish";
	font-weight: 700;
	font-style: normal;
	src: url(fonts/mulish-bold.ttf);
}
/*------------------------------------------------------------
	デフォルトスタイル
------------------------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, figcaption, figure {
	margin: 0;
	padding: 0;
	background: transparent;
	border: 0;
	outline: 0;
	font-size: 1em;
	box-sizing: border-box;
}
html {
	font-size: 62.5%;
}
@media all and (min-width: 897px) and (max-width: 1535px) {
	html {
		font-size: 0.651vw;
	}
}
body, table, input, textarea, select, option {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, main {
	display: block;
}
ol, ul {
	list-style: none;
	box-sizing: border-box;
}
blockquote, q {
	quotes: none;
}
:focus {
	outline: 0;
}
ins {
	text-decoration: none;
}
del {
	text-decoration: line-through;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
a,
a:link {
	color: inherit;
	text-decoration: none;
}
a:visited {
	color: inherit;
}
a:hover {
	color: inherit;
}
a:active {
	color: inherit;
}
/*------------------------------------------------------------
	レイアウト
------------------------------------------------------------*/
body {
	color: #1E1E1E;
	font-size: 1.6rem;
	line-height: 1.5;
	text-size-adjust: none;
	-webkit-text-size-adjust: none;
	background-color: #FFF;
}
body.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
}
#container {
	position: relative;
	text-align: left;
	overflow: hidden;
}
@media all and (min-width: 897px) {
	body.fixed {
		overflow-y: scroll;
	}
	.sp {
		display: none !important;
	}
	a[href^="tel:"] {
		cursor: default;
		pointer-events: none;
	}
}
@media all and (max-width: 896px) {
	body {
		font-size: 1.3rem;
	}
	a:hover,
	a:hover img {
		opacity: 1 !important;
	}
	.pc {
		display: none !important;
	}
}
/*------------------------------------------------------------
	ヘッダー
------------------------------------------------------------*/
#gHeader h1 {
	position: fixed;
	left: 5rem;
	top: 5rem;
	z-index: 100;
	mix-blend-mode: multiply;
}
#gHeader h1 a {
	min-height: 32px;
	display: flex;
	align-items: center;
}
#gHeader h1 img {
	width: 18rem;
}
#gHeader h1 .txt {
	margin-left: 5rem;
	display: inline-block;
	color: #003893;
	font-weight: 500;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
}
@media all and (min-width: 897px) and (max-width: 1535px) {
	#gHeader h1 .txt {
		margin-left: 2rem;
	}
}
@media all and (max-width: 896px) {
	#gHeader {
		height: 73px;
		background: #fff;
	}
	#gHeader h1 {
		left: 25px;
		top: 25px;
	}
	#gHeader h1 a {
		min-height: initial;
		display: block;
	}
	#gHeader h1 img {
		width: 105px;
	}
	#gHeader h1 .txt {
		display: none !important;
	}
}
/*------------------------------------------------------------
	gNavi
------------------------------------------------------------*/
#gNavi {
	position: absolute;
	right: 11.7rem;
	top: 5.9rem;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	z-index: 50;
}
#gNavi .naviList {
	height: 21px;
	display: flex;
	align-items: center;
	gap: 0 3rem;
}
#gNavi .naviList li a {
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.13em;
	position: relative;
	transition: 0.3s;
}
#gNavi .naviList li a::after {
	width: 0;
	height: 1px;
	position: absolute;
	bottom: -2px;
	left: 50%;
	background: #003893;
	transition: .3s;
	transform: translateX(-50%);
	content: '';
}
#gNavi .naviList li a .txt {
	height: 1.5em;
	display: block;
	overflow: hidden;
}
#gNavi .naviList li a .before,
#gNavi .naviList li a .after {
	display: block;
	line-height: 1.5em;
	transition: transform .5s cubic-bezier(.2, 0, 0, 1), opacity .5s cubic-bezier(.2, 0, 0, 1);
	will-change: transform;
}
#gNavi .naviList li a .after {
	opacity: 0;
}
#gNavi .naviList li a:hover {
	color: #003893;
}
#gNavi .naviList li a:hover::after {
	width: 100%;
}
#gNavi .naviList li a:hover .before {
	transform: translateY(-130%);
	opacity: 0;
}
#gNavi .naviList li a:hover .after {
	transform: translateY(-100%);
	opacity: 1;
}
#gNavi .naviList .current a {
	color: #003893;
}
#gNavi .naviList .current a::after {
	width: 100%;
}
.index #gNavi .naviList li a {
	color: #fff;
}
.index #gNavi .naviList li a::after {
	background: #fff;
}
.menu {
	width: 20px;
	height: 21px;
	position: fixed;
	right: 5rem;
	top: 5.8rem;
	z-index: 1000;
	cursor: pointer;
	mix-blend-mode: multiply;
}
.menu span {
	width: 100%;
	height: 2px;
	position: absolute;
	left: 0;
	top: 4px;
	background: #003893;
	overflow: hidden;
	transition: transform 0.6s cubic-bezier(0.32, 0.1, 0, 1);
}
.index .menu {
	mix-blend-mode: difference;
}
.index .menu span {
	background: #fff;
}
.menu span::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background-color: rgba(142, 142, 142, 1);
	content: '';
	transform: translateX(-100%);
	transform-origin: left center;
	animation-duration: 2s;
	animation-fill-mode: forwards;
	z-index: 1;
}
@keyframes lineAni {
	0% {
		transform: translateX(-100%);
	}
	50% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(100%);
	}
}
.menu span:nth-child(2) {
	top: 10px;
}
.menu span:nth-child(2):before {
	animation-delay: .1s;
}
.menu span:nth-child(3) {
	top: 16px;
}
.menu span:nth-child(3):before {
	animation-delay: .2s;
}
.menu.on {
	mix-blend-mode: normal;
}
.menu.on span {
	background: #fff;
}
.menu.on span:nth-child(1) {
	transform: translateX(0) translateY(6px) rotate(45deg);
}
.menu.on span:nth-child(2) {
	transform-origin: 100% 50%;
	transform: scale(0, 1);
}
.menu.on span:nth-child(3) {
	transform: translateX(0) translateY(-6px) rotate(-45deg);
}
.menuBox {
	width: 100%;
	height: 100%;
	position: fixed;
	left: 0;
	top: 0;
	z-index: 999;
	opacity: 0;
	overflow: hidden;
	visibility: hidden;
	user-select: none;
	transition: 0.5s;
}
.menuBox.open {
	opacity: 1;
	visibility: visible;
	user-select: auto;
}
.menuBox .menuBg01 {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: rgba(0, 0, 0, 0.3);
	transition: 0.5s;
	opacity: 0;
}
.menuBox.open .menuBg01 {
	opacity: 1;
}
.menuBox .menuBg02 {
	width: 768px;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	background: #003893;
	transform: translateX(100%);
	transition: 0.5s;
	z-index: 1;
}
.menuBox.open .menuBg02 {
	transform: translateX(0);
}
.menuBox .menuWrap {
	width: 768px;
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	color: #fff;
	font-size: 1.4rem;
	letter-spacing: 0.06em;
	overflow-x: hidden;
	overflow-y: auto;
	z-index: 20;
}
.menuBox .innerBox {
	padding: 139px 28px 100px 100px;
	min-height: 100%;
}
.menuBox .menuList {
	margin-bottom: 32px;
	font-size: 1.2rem;
	position: relative;
	z-index: 1;
}
.menuBox .menuList li {
	margin-bottom: 29px;
	transform: translateX(30px);
	transition: 0.5s;
	transition-delay: 0.3s;
	opacity: 0;
}
.menuBox.open .menuList li {
	transform: translateX(0);
	opacity: 1;
}
.menuBox .menuList li:last-child {
	margin-bottom: 0;
}
.menuBox .menuList li a {
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	vertical-align: top;
	letter-spacing: 0.2em;
}
.menuBox .menuList li a .jp {
	height: 2em;
	position: relative;
	display: inline-flex;
	flex-direction: column;
	line-height: 2em;
	overflow: hidden;
}
.menuBox .menuList li a .jp span {
	display: inline-block;
	transition: transform .5s cubic-bezier(.2, 0, 0, 1), opacity .5s cubic-bezier(.2, 0, 0, 1);
	will-change: transform;
}
.menuBox .menuList li a .en {
	height: 1.35em;
	display: inline-flex;
	flex-direction: column;
	position: relative;
	font-size: 3.4rem;
	line-height: 1.35em;
	letter-spacing: 0.1em;
	overflow: hidden;
}
.menuBox .menuList li a .en span {
	display: inline-block;
	transition: transform .5s cubic-bezier(.2, 0, 0, 1), opacity .5s cubic-bezier(.2, 0, 0, 1);
	will-change: transform;
}
.menuBox .menuList li a .after {
	opacity: 0;
}
.menuBox .menuList li a .jp::after,
.menuBox .menuList li a .en::after {
	width: 0;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 50%;
	background: #fff;
	transition: .3s;
	transform: translateX(-50%);
	content: '';
}
.menuBox .menuList li .subList {
	margin: 26px 0 31px 50px;
}
.menuBox .menuList li .subList li {
	margin-bottom: 16px;
}
.menuBox .menuList li .subList li:last-child {
	margin-bottom: 0;
}
.menuBox .menuList li .subList li a .en {
	font-size: 2rem;
	font-weight: 400;
}
.menuBox .logoBox {
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 1;
}
.menuBox .logoBox .link {
	margin-top: 30px;
	width: calc(100% - 200px);
	display: flex;
	align-items: flex-start;
	transform: translateX(30px);
	transition: 0.5s;
	transition-delay: 0.3s;
	opacity: 0;
}
.menuBox.open .logoBox .link {
	transform: translateX(0);
	opacity: 1;
}
.menuBox .logoBox .link a {
	display: inline-block;
	position: relative;
}
.menuBox .logoBox .link a::after {
	width: 0;
	height: 1px;
	position: absolute;
	bottom: -2px;
	left: 50%;
	background: #fff;
	transition: .3s;
	transform: translateX(-50%);
	content: '';
}
.menuBox .logoBox .link a .jp {
	display: flex;
	flex-direction: column;
	height: 1.5em;
	line-height: 1.5em;
	overflow: hidden;
}
.menuBox .logoBox .link a .jp span {
	display: block;
	transition: transform .5s cubic-bezier(.2, 0, 0, 1), opacity .5s cubic-bezier(.2, 0, 0, 1);
	will-change: transform;
}
.menuBox .logoBox .link a .jp .after {
	opacity: 0;
}
.menuBox .logoBox .link .txt {
	margin: 0 0.3em;
}
.menuBox .logoBox .logo {
	width: 192px;
	transform: translateX(30px);
	transition: 0.5s;
	transition-delay: 0.3s;
	opacity: 0;
}
.menuBox.open .logoBox .logo {
	transform: translateX(0);
	opacity: 1;
}
.menuBox .logoBox .logo a {
	display: inline-block;
	transition: 0.2s;
}
@media all and (min-width: 897px) {
	.menuBox .menuList li a:hover .jp::after,
	.menuBox .menuList li a:hover .en::after {
		width: 100%;
	}
	.menuBox .menuList li a:hover .before {
		transform: translateY(-130%);
		opacity: 0;
	}
	.menuBox .menuList li a:hover .after {
		transform: translateY(-100%);
		opacity: 1;
	}
	.menuBox .logoBox .link a:hover::after {
		width: 100%;
	}
	.menuBox .logoBox .link a:hover .before {
		transform: translateY(-130%);
		opacity: 0;
	}
	.menuBox .logoBox .link a:hover .after {
		transform: translateY(-100%);
		opacity: 1;
	}
	.menuBox .logoBox .logo a:hover {
		opacity: 0.7;
	}
	.index #gNavi .naviList li a:hover {
		color: #003893;
	}
	.index #gNavi .naviList li a:hover::after {
		background: #003893;
	}
	.menu:hover span::before {
		animation-name: lineAni;
		animation-play-state: running;
	}
}
@media all and (min-width: 897px) and (max-width: 1535px) {
	#gNavi .naviList {
		gap: 0 2rem
	}
}
@media all and (max-width: 896px) {
	#gNavi {
		display: none;
	}
	.menu {
		right: 25px;
		top: 25px;
	}
	.menu span {
		height: 1px;
	}
	.menuBox .menuBg02,
	.menuBox .menuWrap {
		width: 100%;
	}
	.menuBox .innerBox {
		padding: 60px 25px;
	}
	.menuBox .menuList {
		margin-bottom: 20px;
	}
	.menuBox .menuList li {
		margin-bottom: 20px;
	}
	.menuBox .menuList li:last-child {
		margin-bottom: 0;
	}
	.menuBox .menuList li a .en {
		font-size: 2.4rem;
	}
	.menuBox .menuList li .subList {
		margin: 15px 0 15px 2em;
	}
	.menuBox .menuList li .subList li {
		margin-bottom: 10px;
	}
	.menuBox .menuList li .subList li:last-child {
		margin-bottom: 0;
	}
	.menuBox .menuList li .subList li a .en {
		font-size: 1.7rem;
	}
	.menuBox .logoBox {
		display: block;
	}
	.menuBox .logoBox .link {
		margin: 0 0 20px;
		width: auto;
	}
	.menuBox .logoBox .logo {
		width: auto;
		text-align: center;
	}
}
/*------------------------------------------------------------
	pagePath
------------------------------------------------------------*/
#pagePath {
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}
#pagePath li {
	margin-right: 3px;
	display: inline;
	position: relative;
}
#pagePath li:not(:last-child)::after {
	margin-left: 10px;
	width: 0;
	height: 0;
	display: inline-block;
	border-left: 4px solid #1E1E1E;
	border-right: 4px solid transparent;
	border-top: 2px solid transparent;
	border-bottom: 2px solid transparent;
	transform: translateY(-50%);
	content: '';
}
#pagePath li a {
	position: relative;
	color: #003893;
	transition: 0.3s;
}
#pagePath li a:hover {
	opacity: 0.7;
}
#pagePath li a::after {
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: 0;
	background: #003893;
	content: '';
}
@media all and (max-width: 896px) {
	#pagePath {
		font-size: 0.8rem;
		line-height: 1.9;
	}
	#pagePath li {
		margin-right: 0;
	}
	#pagePath li:not(:last-child)::after {
		margin-left: 5px;
		margin-right: -4px;
		vertical-align: -4px;
		border-left: 6px solid #1E1E1E;
		border-right: 6px solid transparent;
		border-top: 3px solid transparent;
		border-bottom: 3px solid transparent;
	}
}
/*------------------------------------------------------------
	フッター
------------------------------------------------------------*/
#gFooter .fCtaBox {
	padding: 200px 0;
	position: relative;
	background: #003893;
}
#gFooter .fCtaBox::before {
	width: 100%;
	height: 50%;
	position: absolute;
	left: 0;
	top: 0;
	background: url(img/common/bg01.jpg) no-repeat center top / cover;
	content: '';
}
#gFooter .fCtaBox::after {
	width: 100%;
	height: 50%;
	position: absolute;
	left: 0;
	top: 0;
	background: rgba(0, 56, 147, 0.6);
	content: '';
}
#gFooter .fCtaBox .content {
	padding: 102px 0 97px;
	background: #fff;
}
#gFooter .fCtaBox .innerBox {
	margin: 0 auto;
	width: 1152px;
	max-width: 90%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#gFooter .fCtaBox .textBox {
	width: 55%;
}
#gFooter .fCtaBox .ttl {
	margin-bottom: 30px;
	color: #003893;
	font-size: 6rem;
	letter-spacing: 0.1em;
	line-height: 1.2;
}
#gFooter .fCtaBox .text {
	font-size: 1.6rem;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.03em;
}
#gFooter .fCtaBox .btn {
	margin-bottom: 5px;
	width: 43%;
	max-width: 384px;
}
#gFooter .fCtaBox .btn a {
	display: block;
	position: relative;
	text-align: center;
	color: #fff;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	background: #003893;
	border-radius: 10px;
	overflow: hidden;
}
#gFooter .fCtaBox .btn a::before {
	width: 0%;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	border-radius: inherit;
	background: #001D4D;
	content: '';
	transition: all 0.3s;
}
#gFooter .fCtaBox .btn a span {
	padding: 26px 40px 27px;
	display: block;
	position: relative;
	border-radius: inherit;
	background: url(img/common/icon01.png) no-repeat right 28px center / 11px;
	transition: 0.3s;
	z-index: 1;
}
#gFooter .fBox {
	margin: 0 auto;
	padding: 96px 0 112px;
	width: 1536px;
	max-width: 95%;
	display: flex;
	justify-content: space-between;
}
#gFooter .fNaviBox {
	max-width: 50%;
	font-size: 1.6rem;
	letter-spacing: 0.12em;
}
#gFooter .fNaviList {
	margin-bottom: 41px;
}
#gFooter .fNaviList li {
	margin-bottom: 40px;
	line-height: 1.25;
}
#gFooter .fNaviList li:last-child {
	margin-bottom: 0;
}
#gFooter .fNaviList li a {
	padding-left: 22px;
	display: inline-block;
	vertical-align: top;
	position: relative;
	color: #003893;
	transition: 0.3s;
}
#gFooter .fNaviList li a:hover {
	opacity: 0.7;
}
#gFooter .fNaviList > li > a::before {
	position: absolute;
	left: -9px;
	top: 0;
	color: #B4B4B5;
	font-size: 3rem;
	line-height: 0.72;
	content: '・';
}
#gFooter .fNaviList li .subList {
	margin: 9px 0 -5px 24px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 17px;
	font-size: 1.4rem;
	font-weight: 400;
}
#gFooter .fNaviList li .subList li {
	margin: 0;
}
#gFooter .fNaviList li .subList li a {
	padding-left: 15px;
	color: #1E1E1E;
	letter-spacing: 0.12em;
}
#gFooter .fNaviList li .subList li a::before {
	width: 10px;
	height: 1px;
	position: absolute;
	left: 0;
	top: 0.8rem;
	background: #B4B4B5;
	content: '';
}
#gFooter .fLinkList {
	margin-left: 2px;
	font-size: 1.4rem;
	letter-spacing: 0.06em;
	line-height: 1.714;
}
#gFooter .fLinkList li a {
	display: inline-block;
	color: #003893;
	transition: 0.3s;
}
#gFooter .fLinkList li a:hover {
	opacity: 0.7;
}
#gFooter .fInfoBox {
	max-width: 50%;
	text-align: right;
}
#gFooter .fLogo {
	margin: 0 -3px 95px 0;
}
#gFooter .fLogo a {
	display: inline-block;
}
#gFooter .fLogo a img {
	width: 150px;
}
#gFooter .fMapLink {
	margin-bottom: 49px;
}
#gFooter .fMapLink a {
	position: relative;
	color: #003893;
	font-size: 1.4rem;
	letter-spacing: 0.11em;
	transition: 0.3s;
}
#gFooter .fMapLink a:hover {
	opacity: 0.7;
}
#gFooter .fMapLink a::before {
	width: 2rem;
	height: 2rem;
	position: absolute;
	left: -2.1rem;
	top: 0.2rem;
	background: url(img/common/icon10.png) no-repeat center center / 100%;
	content: '';
}
#gFooter .fMapLink a::after {
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: -2px;
	background: #003893;
	content: '';
}
#gFooter .fInfoTxt {
	margin-bottom: 44px;
	font-size: 1.4rem;
	font-weight: 400;
	letter-spacing: 0.12em;
	line-height: 1.2;
}
#gFooter .fInfoTxt .ttl {
	margin-bottom: 7px;
	display: block;
	font-weight: 500;
}
#gFooter .pageTop {
	margin-bottom: 25px;
}
#gFooter .pageTop a {
	width: 151px;
	display: inline-block;
	position: relative;
	text-align: left;
	color: #003893;
	font-size: 1.4rem;
	letter-spacing: 0.06em;
	border-radius: 50px;
	border: 1px solid #003893;
	overflow: hidden;
}
#gFooter .pageTop a::before {
	width: 0;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	border-radius: inherit;
	background: #003893;
	transition: 0.3s;
	content: '';
}
#gFooter .pageTop a span {
	padding: 10px 20px 8px;
	display: block;
	position: relative;
	border-radius: inherit;
	background: url(img/common/icon04.png) no-repeat right 18px center / 10px;
	transition: 0.3s;
	z-index: 1;
}
#gFooter address {
	color: #003893;
	font-size: 1.1rem;
	font-style: normal;
	letter-spacing: 0.119em;
}
@media all and (min-width: 897px) {
	#gFooter .fCtaBox .btn a:hover::before {
		width: 100%;
	}
	#gFooter .pageTop a:hover {
		color: #fff;
	}
	#gFooter .pageTop a:hover::before {
		width: 100%;
	}
	#gFooter .pageTop a:hover span {
		background-image: url(img/common/icon05.png);
	}
}
@media all and (max-width: 896px) {
	#gFooter .fCtaBox {
		padding: 50px 0;
	}
	#gFooter .fCtaBox::before {
		height: 150px;
		background-image: url(img/common/bg01_sp.jpg);
	}
	#gFooter .fCtaBox::after {
		height: 150px;
	}
	#gFooter .fCtaBox .content {
		padding: 51px 20px 50px;
	}
	#gFooter .fCtaBox .innerBox {
		width: auto;
		max-width: initial;
		display: block;
	}
	#gFooter .fCtaBox .textBox {
		margin-bottom: 21px;
		width: auto;
	}
	#gFooter .fCtaBox .ttl {
		margin-bottom: 23px;
		font-size: 3rem;
	}
	#gFooter .fCtaBox .text {
		margin: 0 5px;
	}
	#gFooter .fCtaBox .btn {
		margin: 0 auto;
		width: auto;
		max-width: 96.49%;
	}
	#gFooter .fCtaBox .btn a {
		font-size: 1.4rem;
		border-radius: 5px;
	}
	#gFooter .fCtaBox .btn a span {
		padding: 20px 25px 19px;
		background-position: right 14px center;
		border-radius: inherit;
		background-size: 7px;
	}
	#gFooter .fBox {
		padding: 41px 25px 48px;
		width: auto;
		max-width: initial;
		display: block;
	}
	#gFooter .fNaviBox {
		margin-bottom: 50px;
		max-width: initial;
		font-size: 1.4rem;
		letter-spacing: 0.14em;
	}
	#gFooter .fNaviList {
		margin-bottom: 0;
	}
	#gFooter .fNaviList li {
		margin-bottom: 0;
		line-height: 1.23;
		border-bottom: 1px solid #DAE6ED;
	}
	#gFooter .fNaviList li a {
		padding: 11px 10px 11px 0;
		display: block;
		background: url(img/common/icon07.png) no-repeat right center / 7px;
	}
	#gFooter .fNaviList > li > a::before {
		display: none;
	}
	#gFooter .fNaviList li .subList {
		margin: 0;
		padding-left: 105px;
		display: block;
		border-top: 1px solid #DAE6ED;
	}
	#gFooter .fNaviList li .subList li:last-child {
		border-bottom: none;
	}
	#gFooter .fNaviList li .subList li a {
		padding: 11px 10px 11px 0;
		color: #A0A0A0;
	}
	#gFooter .fNaviList li .subList li a::before {
		display: none;
	}
	#gFooter .fInfoBox {
		max-width: initial;
		text-align: center;
	}
	#gFooter .fLogo {
		margin: 0 auto 47px;
		width: 105px;
	}
	#gFooter .fMapLink {
		margin-bottom: 50px;
	}
	#gFooter .fMapLink a {
		margin-left: 15px;
		font-size: 1.2rem;
	}
	#gFooter .fMapLink a::before {
		width: 15px;
		height: 15px;
		left: -17px;
		top: 3px;
	}
	#gFooter .fMapLink a::after {
		bottom: 0;
	}
	#gFooter .fInfoTxt {
		margin-bottom: 49px;
		font-size: 1.2rem;
		line-height: 1.29;
	}
	#gFooter .fInfoTxt .ttl {
		margin-bottom: 12px;
	}
	#gFooter .pageTop a {
		width: auto;
		display: block;
		text-align: center;
	}
	#gFooter .pageTop a span {
		padding: 20px 25px 18px;
		background-image: url(img/common/icon06.png);
		background-position: right 14px center;
		background-size: 7px;
	}
	#gFooter .fLink {
		margin-bottom: 50px;
		color: #003893;
		font-size: 1.2rem;
		font-weight: 400;
		letter-spacing: 0.03em;
	}
	#gFooter address {
		font-size: 1rem;
	}
}
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-YH */
/* clearfix */
.clearfix::after {
	content: "";
	display: block;
	clear: both;
}
/* flex */
.flex, .flexA, .flexB, .flexC {
	display: flex;
	flex-wrap: wrap;
}
.flexA {
	justify-content: space-around;
}
.flexB {
	justify-content: space-between;
}
.flexC {
	justify-content: center;
}
/* fonts */
.mulish {
	font-family: "Mulish", sans-serif;
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	margin: 0 auto;
	width: 1536px;
	max-width: 93.5%;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
}
.innerWrap {
	margin: 0 auto;
	width: 1344px;
	max-width: 95%;
}
.subWrap {
	margin: 0 auto;
	width: 1152px;
	max-width: 90%;
}
@media all and (max-width: 896px) {
	.content {
		margin: 0 25px;
		width: auto !important;
		max-width: initial !important;
	}
	.innerWrap {
		margin: 0 15px;
		width: auto !important;
		max-width: initial !important;
	}
	.subWrap {
		width: auto !important;
		max-width: initial !important;
	}
}
/*------------------------------------------------------------
	pageTitle
------------------------------------------------------------*/
.pageTitle {
	padding: 485px 0 30px;
}
.pageTitle h2 {
	margin-bottom: 15px;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	color: #003893;
}
.pageTitle h2 .en {
	margin: 48px 0 0 -6px;
	display: block;
	font-size: 8rem;
	line-height: 1;
	letter-spacing: 0.1em;
}
@media all and (max-width: 896px) {
	.pageTitle {
		padding: 142px 0 12px;
	}
	.pageTitle h2 {
		margin-bottom: 12px;
		font-size: 1rem;
	}
	.pageTitle h2 .en {
		margin: 24px 0 0;
		font-size: 3rem;
	}
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 106px;
	font-weight: 500;
	position: relative;
	z-index: 1;
}
.headLine01 .txt,
.headLine01 .en {
	display: block;
}
.headLine01 .txt {
	margin-bottom: 46px;
	padding-left: 20px;
	position: relative;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
}
.headLine01 .txt::before {
	width: 10px;
	height: 10px;
	position: absolute;
	left: 0;
	top: 9px;
	border-radius: 50%;
	background: #003893;
	content: '';
}
.headLine01 .en {
	color: #003893;
	font-size: 5rem;
	line-height: 1;
	letter-spacing: 0.1em;
}
.headLine01 .jp {
	margin-top: 26px;
	display: block;
	color: #003893;
	font-size: 3rem;
	letter-spacing: 0.03em;
}
@media all and (max-width: 896px) {
	.headLine01 {
		margin-bottom: 54px;
	}
	.headLine01 .txt {
		margin-bottom: 15px;
		padding-left: 10px;
		font-size: 1rem;
	}
	.headLine01 .txt::before {
		width: 5px;
		height: 5px;
		top: 6px;
	}
	.headLine01 .en {
		font-size: 3.5rem;
	}
	.headLine01 .jp {
		margin-top: 10px;
		font-size: 2rem;
	}
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 29px;
	padding-left: 1.95em;
	position: relative;
	color: #003893;
	font-weight: 500;
	font-size: 3rem;
	letter-spacing: 0.12em;
}
.headLine02 .num {
	position: absolute;
	left: 0;
	top: 50%;
	font-size: 2rem;
	letter-spacing: 0.06em;
	transform: translateY(-50%);
}
.headLine02 .en {
	display: block;
	font-size: 1.2rem;
	letter-spacing: 0.06em;
}
@media all and (max-width: 896px) {
	.headLine02 {
		margin: 0 7px 14px;
		font-size: 1.9rem;
		letter-spacing: 0;
	}
	.headLine02 .num {
		font-size: 1.3rem;
		letter-spacing: 0.03em;
	}
	.headLine02 .en {
		margin-top: 2px;
		font-size: 0.7rem;
		letter-spacing: 0.03em;
	}
}
/*------------------------------------------------------------
	headLine03
------------------------------------------------------------*/
.headLine03 {
	margin-bottom: 77px;
	color: #003893;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.2em;
}
.headLine03 span {
	display: block;
}
.headLine03 .en {
	margin-top: 67px;
	display: block;
	font-size: 6rem;
	letter-spacing: 0.1em;
	line-height: 1;
}
@media all and (max-width: 896px) {
	.headLine03 {
		margin-bottom: 64px;
		font-size: 1rem;
	}
	.headLine03 .en {
		margin-top: 34px;
		font-size: 3rem;
	}
}
/*------------------------------------------------------------
	headLine04
------------------------------------------------------------*/
.headLine04 {
	margin-bottom: 17px;
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.03em;
}
@media all and (max-width: 896px) {
	.headLine04 {
		margin-bottom: 11px;
		font-size: 1.9rem;
	}
}
/*------------------------------------------------------------
	comParallax
------------------------------------------------------------*/
.comParallax {
	width: 100%;
	height: 1020px;
	position: absolute;
	left: 0;
	top: 0;
	overflow: hidden;
	z-index: -1;
}
.comParallax::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #003893;
	opacity: 0.6;
	content: '';
	z-index: 2;
}
.comParallax .parallaxImg {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
.comParallax img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
@media all and (max-width: 896px) {
	.comParallax {
		height: 126px;
	}
}
/*------------------------------------------------------------
	comPrimary
------------------------------------------------------------*/
.comPrimary {
	padding: 95px 0 377px;
	position: relative;
	color: #fff;
}
.comPrimary p {
	font-size: 1.8rem;
	line-height: 2;
	letter-spacing: 0.03em;
}
@media all and (max-width: 896px) {
	.comPrimary {
		padding: 49px 0 179px;
	}
	.comPrimary .comParallax {
		height: 100%;
	}
	.comPrimary p {
		font-size: 1.6rem;
		line-height: 1.8;
	}
}
/*------------------------------------------------------------
	comNavBox
------------------------------------------------------------*/
.comNavBox {
	margin-bottom: 509px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	position: relative;
}
.comNavBox .navList {
	padding-left: 20px;
	width: 48%;
	position: relative;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	color: #003893;
}
.comNavBox .navList::before {
	width: 6px;
	position: absolute;
	left: 0;
	top: 2px;
	bottom: 0;
	border-left: 2px solid #003893;
	border-right: 1px solid #003893;
	box-sizing: border-box;
	content: '';
}
.comNavBox .navList li {
	margin-bottom: 21px;
}
.comNavBox .navList li:last-child {
	margin-bottom: 0;
}
.comNavBox .navList li a {
	display: inline-block;
	padding-left: 2.3em;
	text-indent: -2.3em;
	transition: 0.3s;
}
.comNavBox .navList li a:hover {
	opacity: 0.7;
}
.comNavBox .textBox {
	margin-top: -8px;
	width: 50%;
}
.comNavBox .textBox p {
	font-size: 2rem;
	line-height: 2.4;
	letter-spacing: 0.03em;
}
.comNavBox .img {
	margin-top: -8px;
	width: 384px;
	position: absolute;
	right: -192px;
	top: 100%;
}
@media all and (max-width: 896px) {
	.comNavBox {
		margin-bottom: 0;
		display: block;
	}
	.comNavBox .navList {
		margin-bottom: 46px;
		padding-left: 11px;
		width: auto;
		font-size: 1rem;
		letter-spacing: 0.03em;
	}
	.comNavBox .navList::before {
		width: 3px;
		top: 0;
		left: 1px;
		border-left-width: 1px;
		border-right-width: 0.5px;
	}
	.comNavBox .navList li {
		margin-bottom: 10px;
	}
	.comNavBox .navList li:last-child {
		margin-bottom: 0;
	}
	.comNavBox .textBox {
		margin-top: 0;
		width: auto;
	}
	.comNavBox .textBox p {
		font-size: 1.6rem;
		line-height: 1.8;
		position: relative;
		z-index: 1;
	}
	.comNavBox .img {
		margin: -52px 0 -24px auto;
		width: 192px;
		position: relative;
		right: auto;
		top: auto;
		opacity: 0.3;
	}
}
/*------------------------------------------------------------
	comImgList
------------------------------------------------------------*/
.comImgList li {
	margin-bottom: 223px;
}
.comImgList li:last-child {
	margin-bottom: 0;
}
.comImgList li .headLine02 {
	margin-left: auto;
	width: calc(50% - 96px);
}
.comImgList li .imgBox {
	position: relative;
}
.comImgList li .imgBox::before {
	width: calc(100% + 192px);
	height: 100%;
	position: absolute;
	left: -96px;
	bottom: 0;
	background: #fff;
	content: '';
}
.comImgList li .imgBox .photoBox,
.comImgList li .imgBox .textBox {
	position: relative;
	z-index: 1;
}
.comImgList li .imgBox .photoBox {
	margin: -216px 96px 45px 0;
	width: 50%;
	float: left;
}
.comImgList li .imgBox .photoBox .moive {
	position: relative;
	overflow: hidden;
	aspect-ratio: 576/432;
	z-index: 1;
}
.comImgList li .imgBox .photoBox .moive video {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
.comImgList li .imgBox .photoBox img {
	width: 100%;
	position: relative;
	z-index: 1;
}
.comImgList li .imgBox .textBox {
	padding: 86px 0;
}
.comImgList li .imgBox .textBox p {
	margin-bottom: 62px;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.8125;
}
.comImgList li .imgBox .textBox p:last-child {
	margin-bottom: 0;
}
.comImgList li:nth-child(2n) .headLine02 {
	margin-left: 0;
}
.comImgList li:nth-child(2n) .imgBox .photoBox {
	margin-left: 96px;
	margin-right: 0;
	float: right;
}
@media all and (max-width: 1536px) {
	.comImgList li .imgBox::before {
		width: 116%;
		left: -8%;
	}
}
@media all and (max-width: 1280px) {
	.comImgList li .imgBox::before {
		width: 106%;
		left: -3%;
	}
}
@media all and (max-width: 896px) {
	.comImgList li {
		margin-bottom: 100px;
	}
	.comImgList li:last-child {
		margin-bottom: 0;
	}
	.comImgList li .headLine02 {
		margin-left: 7px;
		width: auto;
	}
	.comImgList li .imgBox::before {
		display: none;
	}
	.comImgList li .imgBox .photoBox {
		margin: 0;
		padding: 0 25px;
		width: auto;
		float: none;
		position: relative;
	}
	.comImgList li .imgBox .photoBox::after {
		width: 100%;
		height: 50%;
		position: absolute;
		left: 0;
		bottom: 0;
		background: #Fff;
		content: '';
	}
	.comImgList li .imgBox .textBox {
		padding: 13px 25px 22px;
		background: #fff;
	}
	.comImgList li .imgBox .textBox p {
		margin-bottom: 29px;
		font-size: 1.6rem;
		line-height: 1.79;
	}
	.comImgList li .imgBox .textBox p:last-child {
		margin-bottom: 0;
	}
	.comImgList li:nth-child(2n) .imgBox .photoBox {
		margin: 0;
		float: none;
	}
}
/*------------------------------------------------------------
	comBtmNavi
------------------------------------------------------------*/
.comBtmNavi {
	padding: 200px 0 198px;
	position: relative;
	color: #fff;
	background: url(img/company/bg01.jpg) no-repeat center center / cover;
}
.comBtmNavi::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: rgba(0, 20, 60, 0.9);
	transition: 0.3s;
	content: '';
}
.comBtmNavi .content {
	gap: 49px 0;
}
.comBtmNavi .link {
	width: 46.8%;
}
.comBtmNavi .link.wid100 {
	width: 100%;
}
.comBtmNavi .link a {
	padding: 0 15px 21px 0;
	width: 100%;
	height: 100%;
	position: relative;
	display: block;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	background: url(img/common/icon09.png) no-repeat right bottom 37px / 9px;
}
.comBtmNavi .link a::after {
	width: 100%;
	height: 3px;
	position: absolute;
	left: 0;
	bottom: 0;
	background: #003893;
	content: '';
	transition: 0.3s;
}
.comBtmNavi .link.wid100 a {
	padding-bottom: 18px;
	background-position: right bottom 35px;
}
.comBtmNavi .link a .en {
	margin-top: 26px;
	display: block;
	font-size: 2.8rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
@media all and (min-width: 897px) {
	.comBtmNavi .link a:hover:after {
		background: #fff;
	}
}
@media all and (max-width: 896px) {
	.comBtmNavi {
		padding: 50px 0 49px;
		background-image: url(img/company/bg01_sp.jpg);
	}
	.comBtmNavi .content {
		margin: 0 20px 0 28px;
		display: block;
	}
	.comBtmNavi .link {
		margin-bottom: 24px;
		width: auto;
	}
	.comBtmNavi .link.wid100 {
		margin-bottom: 24px;
		width: auto;
	}
	.comBtmNavi .link:last-child {
		margin-bottom: 0;
	}
	.comBtmNavi .link a {
		padding: 0 10px 5px 0;
		font-size: 0.8rem;
		background-position: right 1px bottom 12px;
		background-size: 5px;
	}
	.comBtmNavi .link a::after {
		height: 2px;
	}
	.comBtmNavi .link.wid100 a {
		padding-bottom: 9px;
		font-size: 1rem;
		background-position: right 1px bottom 17px;
	}
	.comBtmNavi .link a .en {
		margin-top: 2px;
		font-size: 1.6rem;
	}
	.comBtmNavi .link.wid100 a .en {
		margin-top: 13px;
	}
}
/*------------------------------------------------------------
	wp-pagenavi
------------------------------------------------------------*/
.wp-pagenavi {
	margin-top: 100px;
	padding: 0 180px;
	min-height: 40px;
	font-size: 0;
	clear: both;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	gap: 15px 20px;
	position: relative;
}
.wp-pagenavi a,
.wp-pagenavi span {
	color: #AFCAE5;
	font-size: 1.6rem;
	font-family: "Mulish", sans-serif;
	display: inline-block;
	text-decoration: none;
	border: none;
	padding: 0;
	margin: 0;
}
.wp-pagenavi a:hover,
.wp-pagenavi span.current {
	border: none;
	color: #003893;
}
.wp-pagenavi .first,
.wp-pagenavi .last,
.wp-pagenavi .pages {
	display: none;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	padding: 10px 18px;
	width: 120px;
	height: 40px;
	display: flex;
	align-items: center;
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	border-radius: 50px;
	position: absolute;
	top: 0;
	background: url(img/common/icon01.png) no-repeat right 19px center / 11px;
	overflow: hidden;
}
.wp-pagenavi .previouspostslink::before,
.wp-pagenavi .nextpostslink::before {
	width: 100%;
	height: 100%;
	border-radius: inherit;
	position: absolute;
	left: 0;
	top: 0;
	background: #003893;
	content: '';
	z-index: -2;
}
.wp-pagenavi .previouspostslink::after,
.wp-pagenavi .nextpostslink::after {
	width: 0;
	height: 100%;
	border-radius: inherit;
	position: absolute;
	left: 0;
	top: 0;
	background: #001D4D;
	content: '';
	z-index: -1;
	transition: all 0.3s;
	transform: none;
}
.wp-pagenavi .previouspostslink {
	justify-content: flex-end;
	left: -5px;
	background-image: url(img/common/icon03.png);
	background-position: left 19px center;
}
.wp-pagenavi .nextpostslink {
	right: -5px;
}
.wp-pagenavi .previouspostslink:hover,
.wp-pagenavi .nextpostslink:hover {
	color: #fff;
}
@media all and (min-width: 897px) {
	.wp-pagenavi .previouspostslink:hover::after,
	.wp-pagenavi .nextpostslink:hover::after {
		width: 100%;
	}
}
@media all and (max-width: 896px) {
	.wp-pagenavi {
		margin-top: 50px;
		padding: 0 0 50px;
		min-height: 30px;
		gap: 5px 15px;
	}
	.wp-pagenavi a,
	.wp-pagenavi span {
		font-size: 1.4rem;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		padding: 4px 15px;
		width: 40%;
		height: 30px;
		top: auto;
		transform: none;
		bottom: 0;
		font-size: 1.4rem;
		background-size: 8px auto;
		background-position: right 10px center;
	}
	.wp-pagenavi .previouspostslink {
		left: 0;
		background-position: left 10px center;
	}
	.wp-pagenavi .nextpostslink {
		right: 0;
	}
}
/*------------------------------------------------------------
	comBtn
------------------------------------------------------------*/
.comBtn a {
	width: 192px;
	display: inline-block;
	position: relative;
	vertical-align: top;
	color: #fff;
	letter-spacing: 0.06em;
	border-radius: 40px;
	background: #003893;
	overflow: hidden;
}
.comBtn a::before {
	width: 0;
	height: 100%;
	position: absolute;
	bottom: 0;
	left: 0;
	border-radius: inherit;
	background: #001D4D;
	content: '';
	transition: all 0.3s;
}
.comBtn a span {
	padding: 20px 45px 20px 30px;
	display: block;
	position: relative;
	background: url(img/common/icon01.png) no-repeat right 28px center / 11px;
	z-index: 1;
	transition: all 0.3s;
}
.comBtn.white a {
	color: #003893;
	background: #fff;
	overflow: initial;
	-webkit-mask-image: -webkit-radial-gradient(#fff, #003893);
}
.comBtn.white a span {
	background-image: url(img/common/icon02.png);
}
@media all and (min-width: 897px) {
	.comBtn a:hover::before {
		width: 100%;
	}
	.comBtn.white a::after {
		width: calc(100% + 2px);
		height: calc(100% + 2px);
		position: absolute;
		bottom: -1px;
		left: -1px;
		border-radius: 40px;
		border: 2px solid #003893;
		box-sizing: border-box;
		content: '';
	}
	.comBtn.white a:hover {
		color: #fff;
	}
	.comBtn.white a:hover span {
		background-image: url(img/common/icon01.png);
	}
}
@media all and (max-width: 896px) {
	.comBtn a {
		width: auto;
		display: block;
		font-size: 1.4rem;
		font-weight: 400;
		text-align: center;
	}
	.comBtn a span {
		padding: 20px 30px;
		background-image: url(img/common/icon08.png);
		background-size: 7px;
		background-position: right 14px center;
	}
}
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#index .bgBox {
	position: relative;
	overflow: hidden;
}
#index .bgBox::before {
	width: 100%;
	min-width: 1920px;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 0;
	background: url(img/index/bg01.png) no-repeat center top / 100% auto;
	content: '';
	z-index: 1;
	transform: translateX(-50%);
}
#index .fvBox {
	height: 100vh;
	min-height: 640px;
	display: flex;
	position: relative;
}
#index .fvBox .movie {
	position: absolute;
	right: 0;
	top: 0;
	width: 51%;
	height: 100%;
	overflow: hidden;
	z-index: 0;
}
#index .fvBox .movie::after {
	width: 100%;
	height: 25%;
	position: absolute;
	left: 0;
	bottom: -1px;
	background: linear-gradient(transparent 0%, #fff 98%, #fff 100%);
	z-index: 2;
	content: '';
}
#index .fvBox .movie video {
	width: 100%;
	height: 103.5%;
	position: absolute;
	top: 0;
	object-fit: cover;
}
#index .fvBox .innerBox {
	padding: 0 0 30px 60px;
	width: 50%;
	height: 100%;
	max-height: 1080px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 2;
}
#index .fvBox .innerBox h2 {
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	position: relative;
	z-index: 3;
}
#index .fvBox .innerBox h2 .en {
	margin: 0 0 15px -4px;
	display: block;
	font-size: 5.4rem;
	letter-spacing: 0.04em;
	color: #003893;
	line-height: 1.111;
}
#index .fvBox .innerBox .linkBox {
	width: 387px;
	display: flex;
	flex-wrap: wrap;
	position: absolute;
	left: 10rem;
	bottom: 51px;
	gap: 40px 28px;
	z-index: 5;
}
#index .fvBox .innerBox .linkBox .link {
	width: 113px;
}
#index .fvBox .innerBox .linkBox .link a {
	display: block;
	position: relative;
}
#index .fvBox .innerBox .linkBox .link a:hover {
	opacity: 0.7;
}
#index .fvBox .innerBox .linkBox .link a .imgtext {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
#index .fvBox .innerBox .linkBox .newsList {
	width: 100%;
}
#index .fvBox .innerBox .linkBox .newsList li {
	position: relative;
	border-bottom: 1px solid #DAE6ED;
}
#index .fvBox .innerBox .linkBox .newsList li::after {
	width: 30px;
	height: 1px;
	position: absolute;
	right: 0;
	bottom: -1px;
	background: #003893;
	z-index: 1;
	content: '';
	transition: 0.5s;
}
#index .fvBox .innerBox .linkBox .newsList li a {
	padding: 8px 0;
	display: block;
}
#index .fvBox .innerBox .linkBox .newsList li .date {
	margin-bottom: 2px;
	font-size: 1.6rem;
	letter-spacing: 0.03em;
}
#index .fvBox .innerBox .linkBox .newsList li .text {
	font-size: 1.8rem;
	letter-spacing: 0.03em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	transition: 0.3s;
}
#index .fvBox .scrollBtn {
	width: 12px;
	position: absolute;
	right: -6px;
	bottom: 0;
	z-index: 5;
}
#index .fvBox .scrollBtn a {
	padding-bottom: 90px;
	display: block;
	position: relative;
}
#index .fvBox .scrollBtn a:hover {
	opacity: 0.7;
}
#index .fvBox .scrollBtn a .line {
	margin-left: -1px;
	width: 1px;
	height: 80px;
	position: absolute;
	left: 50%;
	bottom: 0;
	background: #e6e6e6;
}
#index .fvBox .scrollBtn a .line::before {
	width: 1px;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: linear-gradient(to bottom, #003893 50%, rgba(230, 230, 230, 0) 50%);
	background-position: 0 100%;
	background-size: 100% 200%;
	animation: scrolldown 2.2s cubic-bezier(0.76, 0, 0.3, 1) forwards infinite;
	content: '';
	z-index: 1;
}
@keyframes scrolldown {
	0% {
		background-position: 0 100%;
	}
	75% {
		background-position: 0 0;
	}
	100% {
		background-position: 0 -100%;
	}
}
#index .about {
	padding: 470px 0 218px;
	position: relative;
	color: #fff;
	z-index: 3;
}
#index .about h2 {
	margin-bottom: 38px;
	font-size: 3.4rem;
	font-weight: 400;
	line-height: 1.4;
	letter-spacing: 0.03em;
	text-shadow: 0 0 2px #003893;
}
#index .about p {
	font-size: 1.8rem;
	letter-spacing: 0.03em;
	line-height: 2;
	text-shadow: 0 0 2px #003893;
}
#index .about .img {
	margin: -9.3rem 0 0 21.3rem;
	width: 40rem;
}
#index .secBox {
	padding: 400px 0;
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#index .secBox .img {
	width: 43.4rem;
	position: absolute;
	top: 70px;
	right: 0;
}
#index .secBox .photoBox,
#index .secBox .textBox {
	position: relative;
	z-index: 1;
}
#index .secBox .photoBox {
	padding: 129px 0;
	width: 40%;
	position: relative;
}
#index .secBox .photoBox .comParallax {
	width: calc(100% - 47px);
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
#index .secBox .photoBox .photo {
	margin-left: auto;
	width: 68.5%;
	position: relative;
	z-index: 1;
	overflow: hidden;
	aspect-ratio: 525/700;
}
#index .secBox .photoBox .photo .inner {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}
#index .secBox .photoBox .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	left: 0;
	top: 0;
}
#index .secBox .textBox {
	padding-top: 16px;
	width: 50%;
	order: 1;
}
#index .secBox .textBox .inner {
	width: 578px;
	max-width: 90%;
	position: relative;
}
#index .secBox .textBox .headLine03 {
	margin-bottom: 127px;
	position: relative;
	z-index: 1;
}
#index .secBox .textBox .subSec {
	margin-bottom: 72px;
	position: relative;
	z-index: 1;
}
#index .secBox .textBox .subSec p {
	margin-bottom: 27px;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.03em;
}
#index .secBox .textBox .subSec p:last-child {
	margin-bottom: 0;
}
#index .secBox .textBox .subSec .link a {
	height: 1.5em;
	position: relative;
	display: inline-flex;
	flex-direction: column;
	color: #003893;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.5em;
	overflow: hidden;
}
#index .secBox .textBox .subSec .link a::after {
	width: 0;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 50%;
	background: #003893;
	transition: .3s;
	transform: translateX(-50%);
	content: '';
}
#index .secBox .textBox .subSec .link a span {
	display: inline-block;
	transition: transform .5s cubic-bezier(.2, 0, 0, 1), opacity .5s cubic-bezier(.2, 0, 0, 1);
	will-change: transform;
}
#index .secBox .textBox .subSec .link a .after {
	opacity: 0;
}
#index .product {
	padding: 351px 0 400px;
	position: relative;
}
#index .product .comParallax {
	height: 700px;
}
#index .product .imgBox {
	display: flex;
	justify-content: space-between;
	position: relative;
}
#index .product .imgBox::before {
	width: 70%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #EFF5F9;
	content: '';
}
#index .product .imgBox .textBox {
	padding: 101px 0;
	width: 50%;
	position: relative;
	z-index: 1;
}
#index .product .imgBox .textBox .img {
	width: 32rem;
	position: absolute;
	left: 50px;
	bottom: -182px;
}
#index .product .imgBox .textBox .subBox {
	margin-left: auto;
	width: 576px;
	max-width: 90%;
	position: relative;
	z-index: 1;
}
#index .product .imgBox .textBox .headLine03 {
	margin-bottom: 127px;
}
#index .product .imgBox .textBox p {
	margin-bottom: 66px;
	line-height: 1.8;
	letter-spacing: 0.03em;
	font-weight: 400;
}
#index .product .imgBox .photoBox {
	margin: 93px 0 86px;
	width: 40%;
}
#index .product .imgBox .photoBox .photo {
	width: 100%;
	position: relative;
	overflow: hidden;
	z-index: 1;
	aspect-ratio: 768/576;
}
#index .product .imgBox .photoBox .inner {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
#index .product .imgBox .photoBox img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
#index .company {
	padding-top: 199px;
	position: relative;
	color: #fff;
	background: #003893;
}
#index .company .img {
	width: 19.2rem;
	position: absolute;
	right: 2.6%;
	top: 100px;
}
#index .company .ttlBox {
	padding-left: 12.5%;
	width: 48%;
}
#index .company .ttlBox .headLine03 {
	color: #fff;
}
#index .company .innerBox {
	margin-bottom: 200px;
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 1;
}
#index .company .innerBox .textBox {
	width: 50%;
}
#index .company .innerBox .textBox .txtList {
	margin-bottom: 5px;
}
#index .company .innerBox .textBox .txtList dt {
	margin-bottom: 20px;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.06em;
}
#index .company .innerBox .textBox .txtList dt .txt {
	margin-right: 2.9rem;
	display: inline-block;
	vertical-align: top;
}
#index .company .innerBox .textBox .txtList dt .map {
	margin-top: 0.3rem;
	display: inline-block;
	vertical-align: top;
	text-decoration: underline;
	font-size: 1.4rem;
	letter-spacing: 0.08em;
}
#index .company .innerBox .textBox .txtList dt .map:hover {
	opacity: 0.7;
}
#index .company .innerBox .textBox .txtList dt .map::before {
	width: 2rem;
	height: 2rem;
	display: inline-block;
	vertical-align: middle;
	background: url(img/common/icon14.png) no-repeat center center / 100%;
	content: '';
}
#index .company .innerBox .textBox .txtList dd {
	margin-bottom: 39px;
	position: relative;
	padding-left: 2.4rem;
	font-weight: 400;
	letter-spacing: 0.03em;
}
#index .company .innerBox .textBox .txtList dd:last-child {
	margin-bottom: 0;
}
#index .company .innerBox .textBox .txtList dd::before {
	width: 1.4rem;
	height: 0.2rem;
	position: absolute;
	left: 0;
	top: 1.1rem;
	background: #FFFFFF;
	content: '';
}
#index .company .photo {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1920/820;
}
#index .company .photo .inner {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}
#index .company .photo .inner img {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
#index .recruit .img {
	width: 136px;
	top: -85px;
}
#index .recruit .textBox {
	padding-top: 0;
}
#index .news {
	padding: 200px 0;
	background: #EFF5F9;
}
#index .news .content {
	padding: 171px 0 200px;
	background: #fff;
}
#index .news .ttlBox {
	margin-top: 29px;
	width: 50%;
	position: relative;
}
#index .news .ttlBox .img {
	width: 137px;
	position: absolute;
	left: 155px;
	top: -80px;
}
#index .news .newsList {
	width: 50%;
}
#index .news .newsList li {
	position: relative;
	border-bottom: 1px solid #DAE6ED;
}
#index .news .newsList li::after {
	width: 30px;
	height: 1px;
	position: absolute;
	right: 0;
	bottom: -1px;
	background: #003893;
	transition: 0.5s;
	z-index: 1;
	content: '';
}
#index .news .newsList li a {
	padding: 28px 0;
	display: block;
}
#index .news .newsList li .date {
	margin-bottom: 17px;
	font-size: 1.6rem;
	letter-spacing: 0.03em;
}
#index .news .newsList li .text {
	padding-right: 30px;
	font-size: 1.8rem;
	letter-spacing: 0.03em;
	background: url(img/common/icon02.png) no-repeat right center / 11px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	transition: 0.3s;
}
@media all and (min-width: 1921px) {
	#index .about {
		padding: 24.479vw 0 11.354vw;
	}
}
@media all and (min-width: 897px) {
	#index .fvBox .innerBox .linkBox .newsList li:hover:after {
		width: 50%;
	}
	#index .fvBox .innerBox .linkBox .newsList li a:hover .text {
		color: #003893;
	}
	#index .secBox .textBox .subSec .link a:hover::after {
		width: 100%;
	}
	#index .secBox .textBox .subSec .link a:hover .before {
		transform: translateY(-130%);
		opacity: 0;
	}
	#index .secBox .textBox .subSec .link a:hover .after {
		transform: translateY(-100%);
		opacity: 1;
	}
	#index .news .newsList li a:hover .text {
		color: #003893;
	}
	#index .news .newsList li:hover::after {
		width: 50%;
	}
}
@media all and (min-width: 897px) and (max-width: 1536px) {
	#index .bgBox::before {
		height: 130%;
		background-size: auto 100%;
	}
}
@media all and (max-width: 896px) {
	#index .bgBox::before {
		margin-left: -1px;
		width: calc(100% + 2px);
		min-width: 375px;
		background-image: url(img/index/bg01_sp.png);
	}
	#index .fvBox {
		height: calc(100vh - 73px);
		min-height: 430px;
		display: block;
	}
	#index .fvBox .movie {
		width: 100%;
	}
	#index .fvBox .movie::after {
		height: 15%;
	}
	#index .fvBox .innerBox {
		padding: 21px 25px;
		width: 100%;
		height: auto;
		max-height: initial;
		display: block;
		position: absolute;
		left: 0;
		bottom: 0;
	}
	#index .fvBox .innerBox h2 {
		margin-bottom: 47px;
		font-size: 1.6rem;
		color: #fff;
	}
	#index .fvBox .innerBox h2 .en {
		margin: 0 0 6px;
		font-size: 2.7rem;
		color: #fff;
	}
	#index .fvBox .innerBox .linkBox {
		width: auto;
		display: block;
		position: static;
	}
	#index .fvBox .innerBox .linkBox .link {
		display: none;
	}
	#index .fvBox .innerBox .linkBox .newsList li::after {
		width: 60px;
	}
	#index .fvBox .innerBox .linkBox .newsList li a {
		padding: 11px 0;
		display: block;
		color: #fff;
	}
	#index .fvBox .innerBox .linkBox .newsList li .date {
		margin-bottom: 8px;
		font-size: 1.4rem;
	}
	#index .fvBox .innerBox .linkBox .newsList li .text {
		font-size: 1.6rem;
	}
	#index .fvBox .scrollBtn {
		display: none;
	}
	#index .about {
		padding: 0;
	}
	#index .about::after {
		width: 100%;
		height: 60vw;
		position: absolute;
		left: 0;
		bottom: 0;
		background: #003893;
		content: '';
	}
	#index .about .subWrap {
		padding: 330px 25px 116px;
		position: relative;
		z-index: 1;
	}
	#index .about h2 {
		margin-bottom: 33px;
		font-size: 2.6rem;
	}
	#index .about p {
		font-size: 1.6rem;
		line-height: 1.8;
		position: relative;
		z-index: 1;
	}
	#index .about .img {
		margin: 0;
		width: 20rem;
		position: absolute;
		left: 25px;
		bottom: 0;
	}
	#index .secBox {
		padding: 99px 0 0;
		display: block;
	}
	#index .secBox .img {
		width: 217px;
		top: 0;
		opacity: 0.3;
	}
	#index .secBox .photoBox {
		padding: 33px 0;
		width: auto;
	}
	#index .secBox .photoBox .comParallax {
		width: 100%;
	}
	#index .secBox .photoBox .photo {
		margin-left: 50px;
		width: auto;
		aspect-ratio: 650/866;
	}
	#index .secBox .textBox {
		margin: 0 25px 100px;
		padding-top: 0;
		width: auto;
	}
	#index .secBox .textBox .inner {
		width: auto;
		max-width: initial;
	}
	#index .secBox .textBox .headLine03 {
		margin-bottom: 63px;
	}
	#index .secBox .textBox .subSec {
		margin-bottom: 50px;
	}
	#index .secBox .textBox .subSec p {
		margin-bottom: 17px;
		font-size: 1.6rem;
	}
	#index .secBox .textBox .subSec .link a {
		font-size: 1.5rem;
	}
	#index .product {
		padding: 0;
		background: #EFF5F9;
	}
	#index .product .comParallax {
		height: calc(100% - 25px);
		top: 25px;
		z-index: auto;
	}
	#index .product .imgBox {
		display: block;
	}
	#index .product .imgBox::before {
		display: none;
	}
	#index .product .imgBox .textBox {
		padding: 100px 25px 75px;
		width: auto;
	}
	#index .product .imgBox .textBox .img {
		width: 160px;
		opacity: 0.3;
		left: auto;
		right: 0;
		bottom: auto;
		top: 0;
	}
	#index .product .imgBox .textBox .subBox {
		width: auto;
		max-width: initial;
	}
	#index .product .imgBox .textBox .headLine03 {
		margin-bottom: 63px;
	}
	#index .product .imgBox .textBox .headLine04 {
		margin-bottom: 9px;
	}
	#index .product .imgBox .textBox p {
		margin-bottom: 46px;
		font-size: 1.6rem;
	}
	#index .product .imgBox .photoBox {
		margin: 0;
		padding: 0 0 50px 25px;
		width: auto;
		position: relative;
	}
	#index .product .imgBox .photoBox .photo {
		aspect-ratio: 700/650;
		z-index: 2;
	}
	#index .company {
		padding-top: 100px;
	}
	#index .company .img {
		width: 96px;
		right: 6.8%;
	}
	#index .company .ttlBox {
		margin-bottom: 49px;
		padding: 0;
		width: auto;
	}
	#index .company .ttlBox .headLine03 {
		margin: 0 100px 63px 0;
	}
	#index .company .ttlBox .comBtn {
		margin-bottom: 0;
		width: auto;
	}
	#index .company .innerBox {
		margin-bottom: 94px;
		display: block;
	}
	#index .company .innerBox .textBox {
		width: auto;
	}
	#index .company .innerBox .textBox .txtList {
		margin-bottom: 0;
	}
	#index .company .innerBox .textBox .txtList dt {
		margin-bottom: 2px;
		font-size: 1.6rem;
		letter-spacing: 0.05em;
	}
	#index .company .innerBox .textBox .txtList dt .txt {
		margin-right: 13px;
	}
	#index .company .innerBox .textBox .txtList dt .map {
		font-size: 1.2rem;
	}
	#index .company .innerBox .textBox .txtList dt .map::before {
		width: 14px;
		height: 14px;
		margin-right: 4px;
		vertical-align: -2px;
	}
	#index .company .innerBox .textBox .txtList dd {
		margin-bottom: 22px;
		padding-left: 19px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#index .company .innerBox .textBox .txtList dd::before {
		height: 1px;
		top: 13px;
	}
	#index .company .photo {
		aspect-ratio: 750/318;
	}
	#index .recruit {
		margin-bottom: 100px;
	}
	#index .recruit .img {
		width: 68px;
		top: 0;
	}
	#index .recruit .headLine04 {
		margin-bottom: 8px;
	}
	#index .recruit .textBox {
		margin-bottom: 79px;
	}
	#index .recruit .textBox .subSec {
		margin-bottom: 48px;
	}
	#index .news {
		padding: 50px 0;
	}
	#index .news .content {
		padding: 49px 25px 75px;
	}
	#index .news .subWrap {
		display: block;
	}
	#index .news .ttlBox {
		margin: 0 0 33px;
		width: auto;
	}
	#index .news .ttlBox .img {
		width: 68px;
		left: 116px;
		top: 4px;
		opacity: 0.3;
	}
	#index .news .newsList {
		width: auto;
	}
	#index .news .newsList li::after {
		width: 60px;
	}
	#index .news .newsList li a {
		padding: 13px 0 11px;
		display: block;
	}
	#index .news .newsList li .date {
		margin-bottom: 6px;
		font-size: 1.4rem;
		font-weight: 400;
	}
	#index .news .newsList li .text {
		padding-right: 25px;
		font-size: 1.6rem;
		line-height: 1.8;
		background: none;
		white-space: initial;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		display: -webkit-box;
	}
}
/*------------------------------------------------------------
	company
------------------------------------------------------------*/
#company .message {
	margin-bottom: 200px;
}
#company .message .content {
	padding: 200px 0;
	background: #EFF5F8;
}
#company .message .ttlBox {
	margin: 0 auto;
	max-width: 1152px;
}
#company .message .ttlBox .img {
	width: 47%;
	max-width: 534px;
	position: absolute;
	right: 1px;
	top: 120px;
}
#company .message .innerBox {
	padding: 91px 0 98px;
	background: #fff;
}
#company .message .innerBox p {
	margin-bottom: 48px;
	font-size: 2rem;
	letter-spacing: 0.03em;
	line-height: 2.4;
}
#company .message .innerBox p:last-child {
	margin-bottom: 0;
}
#company .message .innerBox .name {
	text-align: right;
	font-weight: 400;
	font-size: 1.6rem;
	line-height: 1.6;
}
#company .message .innerBox .name .imgtext {
	margin-left: 1.9rem;
	display: inline-block;
	vertical-align: 0.3rem;
}
#company .message .innerBox .name .imgtext img {
	width: 10.6rem;
}
@media all and (max-width: 896px) {
	#company .message {
		margin-bottom: 0;
		padding: 50px 0 100px;
		background: #EFF5F8;
	}
	#company .message .content {
		padding: 0;
	}
	#company .message .content .innerWrap {
		margin: 0;
	}
	#company .message .ttlBox {
		max-width: initial;
	}
	#company .message .ttlBox .img {
		width: 50%;
		max-width: 160px;
		right: 0;
		top: 0;
		opacity: 0.3;
	}
	#company .message .innerBox {
		padding: 22px 25px 58px;
	}
	#company .message .innerBox p {
		margin-bottom: 29px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#company .message .innerBox .text01 {
		margin-bottom: 22px;
	}
	#company .message .innerBox .name {
		font-size: 1rem;
	}
	#company .message .innerBox .name .imgtext {
		margin-left: 1rem;
		vertical-align: 0.7rem;
	}
	#company .message .innerBox .name .imgtext img {
		width: 8.1rem;
	}
}
/*------------------------------------------------------------
	outline
------------------------------------------------------------*/
#outline .secBox {
	margin-bottom: 202px;
	padding-top: 200px;
	position: relative;
}
#outline .secBox .content {
	padding: 100px 0 199px;
	background: #EFF5F8;
}
#outline .anchorList {
	margin-bottom: 99px;
	padding: 0 2px;
	display: flex;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	border-left: 2px solid #003893;
	border-right: 2px solid #003893;
}
#outline .anchorList li {
	width: 33.33%;
	border-left: 1px solid #003893;
}
#outline .anchorList li:last-child {
	border-right: 1px solid #003893;
}
#outline .anchorList li a {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #003893;
}
#outline .anchorList li a .txt {
	display: inline-block;
	position: relative;
}
#outline .anchorList li a .txt::after {
	width: 0;
	height: 1px;
	position: absolute;
	left: 50%;
	bottom: 0;
	background: #003893;
	content: '';
	transform: translateX(-50%);
	transition: 0.3s;
}
#outline .anchorList li.current a {
	font-weight: 700;
}
#outline .anchorList li.current a .txt::after {
	width: 100%;
}
#outline .whiteBox {
	padding: 109px 0 101px;
	background: #fff;
}
#outline .sec01 table {
	width: 100%;
	border-collapse: collapse;
	position: relative;
}
#outline .sec01 th,
#outline .sec01 td {
	padding: 32px 0 33px;
	text-align: left;
	vertical-align: top;
	line-height: 1.8;
	letter-spacing: 0.03em;
	box-sizing: border-box;
	border-top: 1px solid #C8D2DC;
	border-bottom: 1px solid #C8D2DC;
}
#outline .sec01 th {
	padding-top: 33px;
	width: 8.6%;
	position: relative;
	font-weight: 500;
}
#outline .sec01 th::before {
	width: 100%;
	height: 4px;
	position: absolute;
	left: 0;
	top: -3px;
	background: #003893;
	z-index: 1;
	content: '';
}
#outline .sec01 td {
	padding-left: 5.7%;
	font-size: 1.7rem;
	font-weight: 500;
	line-height: 1.7;
}
#outline .sec01 td .staffList {
	display: flex;
	flex-wrap: wrap;
}
#outline .sec01 td .staffList dt {
	width: 11.8em;
	color: #003893;
	font-weight: 500;
	box-sizing: border-box;
}
#outline .sec01 td .staffList dd {
	width: calc(100% - 11.8em);
	box-sizing: border-box;
}
#outline .sec01 td .office {
	display: flex;
}
#outline .sec01 td .office .text01 {
	width: 20.5%;
	color: #003893;
}
#outline .sec01 td .office .text01 span {
	margin-top: 5px;
	display: block;
	font-size: 1.3rem;
	line-height: 1.8;
}
#outline .sec01 td .office .text02 {
	width: 50.5%;
}
#outline .sec01 td .office .text02 .fax {
	pointer-events: none;
	text-decoration: none;
	cursor: default;
}
#outline .sec01 td .office .text03 {
	flex: 1;
	display: flex;
	align-items: center;
}
#outline .sec01 td .office .text03 a {
	display: inline-block;
	position: relative;
	font-size: 1.4rem;
	color: #013893;
	font-weight: 500;
	letter-spacing: 0.15em;
	transition: 0.3s;
}
#outline .sec01 td .office .text03 a:hover {
	opacity: 0.7;
}
#outline .sec01 td .office .text03 a::before {
	width: 2rem;
	height: 2rem;
	position: absolute;
	left: -2rem;
	top: 0.3rem;
	background: url(img/common/icon10.png) no-repeat center center / 100%;
	content: '';
}
#outline .sec01 td .office .text03 a::after {
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: 0;
	background: #013893;
	content: '';
}
#outline .sec02 {
	padding-top: 200px;
}
#outline .sec02 .comParallax {
	height: 640px;
}
#outline .sec02 .headLine01 {
	margin-bottom: 94px;
}
#outline .sec02 .whiteBox {
	padding: 100px 0;
}
#outline .sec02 .tableBox {
	display: flex;
}
#outline .sec02 .tableBox .sub {
	width: 50%;
}
#outline .sec02 .tableBox table {
	width: 100%;
	border-collapse: collapse;
	border-bottom: 1px solid #C8D2DC;
}
#outline .sec02 .tableBox th,
#outline .sec02 .tableBox td {
	padding: 0 0.9rem;
	vertical-align: middle;
	text-align: left;
	box-sizing: border-box;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 2.43;
	border-top: 1px solid #C8D2DC;
}
#outline .sec02 .tableBox th {
	padding-left: 3rem;
	width: 39.5%;
	color: #fff;
	background: #003893;
	font-weight: 500;
	border-left: 1px solid #C8D2DC;
	border-top: 1px solid #fff;
}
#outline .sec02 .tableBox tr:first-child th {
	border-top-color: #C8D2DC;
}
#outline .sec02 .tableBox td:last-of-type {
	padding: 0;
	width: 8.5%;
	text-align: center;
	border-left: 1px solid #C8D2DC;
}
#outline .sec02 .tableBox .sub01 tr:nth-child(2n-1) td {
	background: #EFF5F8;
}
#outline .sec02 .tableBox .sub02 tr:nth-child(2n) td {
	background: #EFF5F8;
}
#outline .sec02 .tableBox .sub02 td:last-of-type {
	border-right: 1px solid #C8D2DC;
}
#outline .sec03 .headLine01 {
	margin-bottom: 117px;
}
#outline .sec03 .whiteBox {
	padding: 96px 0;
}
#outline .sec03 .subSec {
	padding-bottom: 50px;
}
#outline .sec03 .subSec:last-child {
	border-bottom: 1px solid #C8D2DC;
}
#outline .sec03 .subSec h4 {
	margin-bottom: 51px;
	padding-bottom: 8px;
	position: relative;
	font-size: 3.4rem;
	font-weight: 500;
	font-style: italic;
	letter-spacing: 0.03em;
	color: #003893;
	border-bottom: 1px solid #C8D2DC;
}
#outline .sec03 .subSec h4::after {
	width: 100px;
	height: 4px;
	position: absolute;
	left: 0;
	bottom: -2px;
	background: #003893;
	content: '';
	z-index: 1;
}
#outline .sec03 .subSec .imgList li {
	padding-bottom: 51px;
	margin-bottom: 50px;
	display: flex;
	justify-content: space-between;
	border-bottom: 1px solid #C8D2DC;
}
#outline .sec03 .subSec .imgList li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border-bottom: none;
}
#outline .sec03 .subSec .imgList li .photoBox {
	width: 33.35%;
	order: 1;
}
#outline .sec03 .subSec .imgList li .photoBox a {
	display: block;
	position: relative;
	border: 1px solid #C8D2DC;
}
#outline .sec03 .subSec .imgList li .photoBox a::after {
	width: 30px;
	height: 30px;
	position: absolute;
	right: 9px;
	bottom: 9px;
	background: url(img/company/outline/zoom.png) no-repeat center center / 100%;
	content: '';
	z-index: 1;
}
#outline .sec03 .subSec .imgList li .photoBox a:hover {
	opacity: 0.7;
}
#outline .sec03 .subSec .imgList li .photoBox a img {
	width: 100%;
}
#outline .sec03 .subSec .imgList li .textBox {
	width: 58%;
}
#outline .sec03 .subSec .imgList li .textBox .ttl {
	margin-bottom: 27px;
	font-size: 3rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
#outline .sec03 .subSec .imgList li .textBox .ttl span {
	margin-top: 9px;
	display: block;
	font-size: 1.8rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	color: #003893;
}
#outline .sec03 .subSec .imgList li .textBox p {
	margin-bottom: 48px;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.03em;
}
#outline .sec03 .subSec .imgList li .textBox p:last-child {
	margin-bottom: 0;
}
#outline .sec03 .subSec .imgList li .textBox p a {
	color: #003893;
	font-size: 1.2rem;
	font-style: italic;
	letter-spacing: 0.1em;
	background-image: linear-gradient(currentcolor, currentcolor);
	background-size: 100% 1px;
	background-repeat: no-repeat;
	background-position: 0 100%;
}
#outline .sec03 .subSec .imgList li .textBox p a span::after {
	margin-left: 1rem;
	width: 1.2rem;
	height: 1.2rem;
	display: inline-block;
	background: url(img/common/icon13.png) no-repeat center center / 100%;
	content: '';
}
#outline .sec03 .comParallax {
	height: 640px;
}
@media all and (min-width: 897px) {
	#outline .anchorList li a:hover .txt::after {
		width: 100%;
		opacity: 1;
	}
}
@media all and (max-width: 896px) {
	#outline .pageTitle {
		padding-top: 112px;
		padding-bottom: 14px;
	}
	#outline .secBox {
		margin-bottom: 0;
		padding-top: 126px;
	}
	#outline .secBox .content {
		margin: 0;
		padding: 49px 10px 46px;
	}
	#outline .anchorList {
		margin-bottom: 51px;
		padding: 0 1px;
		text-align: center;
		font-size: 1.2rem;
		line-height: 1.3;
	}
	#outline .whiteBox {
		padding: 29px 25px 50px;
	}
	#outline .sec01 th,
	#outline .sec01 td {
		padding: 15px 0 14px;
		font-size: 1rem;
		line-height: 1.68;
	}
	#outline .sec01 th {
		width: 26.6%;
	}
	#outline .sec01 th.thStyle01 {
		border-bottom: none;
	}
	#outline .sec01 th::before {
		width: 70%;
		height: 2px;
		top: -1px;
	}
	#outline .sec01 td {
		padding-left: 0;
	}
	#outline .sec01 td .staffList dt {
		width: 10.9em;
	}
	#outline .sec01 td .staffList dd {
		width: calc(100% - 10.9em);
	}
	#outline .sec01 td .office {
		display: block;
	}
	#outline .sec01 td .office .text01 {
		margin-bottom: 6px;
		width: auto;
	}
	#outline .sec01 td .office .text01 span {
		font-size: inherit;
	}
	#outline .sec01 td .office .text02 {
		margin-bottom: 10px;
		width: auto;
		line-height: 1.74;
	}
	#outline .sec01 td .office .text03 {
		display: block;
	}
	#outline .sec01 td .office .text03 a {
		margin-left: 1.2em;
		font-size: 0.9rem;
	}
	#outline .sec01 td .office .text03 a::before {
		width: 1.3rem;
		height: 1.3rem;
		left: -1.3rem;
	}
	#outline .sec02 {
		padding-top: 350px;
	}
	#outline .sec02 .comParallax {
		height: 350px;
	}
	#outline .sec03 .comParallax {
		height: 350px;
	}
	#outline .sec02 .headLine01 {
		margin-bottom: 54px;
	}
	#outline .sec02 .whiteBox {
		padding: 25px 20px 50px 25px;
	}
	#outline .sec02 .tableBox {
		display: block;
	}
	#outline .sec02 .tableBox .sub {
		width: auto;
	}
	#outline .sec02 .tableBox th,
	#outline .sec02 .tableBox td {
		padding: 0 0.7rem;
		font-size: 0.9rem;
		letter-spacing: 0.03em;
		line-height: 2.1;
	}
	#outline .sec02 .tableBox th {
		padding-left: 1.3rem;
		width: 35.5%;
		font-size: 1rem;
		line-height: 1.95;
		letter-spacing: 0.03em;
	}
	#outline .sec02 .tableBox td:last-of-type {
		padding: 0;
		border-right: 1px solid #C8D2DC;
	}
	#outline .sec02 .tableBox .sub01 table {
		border-bottom: none;
	}
	#outline .sec03 {
		padding-top: 350px;
	}
	#outline .sec03 .comParallax {
		height: 350px;
	}
	#outline .sec03 .headLine01 {
		margin-bottom: 37px;
	}
	#outline .sec03 .content {
		padding-bottom: 100px;
	}
	#outline .sec03 .whiteBox {
		padding: 38px 20px 50px 25px;
	}
	#outline .sec03 .subSec {
		padding-bottom: 100px;
	}
	#outline .sec03 .subSec:last-child {
		border-bottom: none;
		padding-bottom: 0;
	}
	#outline .sec03 .subSec h4 {
		margin-bottom: 25px;
		padding-bottom: 2px;
		font-size: 1.9rem;
	}
	#outline .sec03 .subSec h4::after {
		width: 50px;
		height: 2px;
		bottom: -1px;
	}
	#outline .sec03 .subSec .imgList li {
		padding-bottom: 49px;
		margin-bottom: 49px;
		display: block;
	}
	#outline .sec03 .subSec .imgList li:last-child {
		margin-bottom: 0;
		padding-bottom: 0;
	}
	#outline .sec03 .subSec .imgList li .photoBox {
		margin-bottom: 25px;
		width: auto;
	}
	#outline .sec03 .subSec .imgList li .photoBox a::after {
		width: 22px;
		height: 22px;
		right: 7px;
		bottom: 7px;
	}
	#outline .sec03 .subSec .imgList li .textBox {
		width: auto;
	}
	#outline .sec03 .subSec .imgList li .textBox .ttl {
		margin-bottom: 22px;
		font-size: 1.9rem;
		letter-spacing: 0;
	}
	#outline .sec03 .subSec .imgList li .textBox .ttl span {
		margin-top: 4px;
		font-size: 1rem;
		letter-spacing: 0.03em;
	}
	#outline .sec03 .subSec .imgList li .textBox p {
		margin-bottom: 18px;
		font-size: 1.2rem;
		word-break: break-all;
		letter-spacing: 0;
	}
	#outline .sec03 .subSec .imgList li .textBox p:last-child {
		margin-bottom: 0;
	}
	#outline .sec03 .subSec .imgList li .textBox p a {
		font-size: 1rem;
		letter-spacing: 0;
	}
	#outline .sec03 .subSec .imgList li .textBox p a span::after {
		display: none;
	}
}
@media all and (max-width: 374px) {
	#outline .sec02 .tableBox th {
		padding-left: 1rem;
	}
	#outline .sec02 .tableBox td {
		padding: 0 0.4rem;
		letter-spacing: 0;
	}
}
@media all and (max-width: 359px) {
	#outline .sec02 .tableBox th {
		padding-left: 0.5rem;
		padding-right: 0.3rem;
		letter-spacing: 0;
	}
}
/*------------------------------------------------------------
	history
------------------------------------------------------------*/
#history .mainBox {
	margin-bottom: 200px;
	padding-top: 200px;
	position: relative;
}
#history .mainBox .content {
	padding: 200px 0;
	background: #EFF5F8;
}
#history .mainBox .headLine01 {
	margin-bottom: 127px;
}
#history .mainBox .innerWrap {
	padding: 97px 0 0;
	position: relative;
	background: #fff;
}
#history .mainBox .photo01 {
	width: 57rem;
	position: absolute;
	right: 0;
	top: 0;
}
#history .mainBox .photo01 img {
	width: 100%;
}
#history .mainBox h4 {
	margin-bottom: 99px;
	text-align: center;
	color: #003893;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
#history .mainBox h4 span {
	display: inline-block;
	padding-bottom: 2px;
	border-bottom: 1px solid #003893;
}
#history .historyBox .boxInner {
	min-height: 385.7rem;
	background: url(img/company/history/bg01.png) no-repeat center top / 50rem 385.7rem;
}
#history .historyBox .left {
	padding: 0 11.5rem 0 15.4rem;
}
#history .historyBox .right {
	margin-left: auto;
	padding: 0 9.6rem 0 11.5rem;
}
#history .historyBox .yearBox {
	width: 50%;
	position: relative;
}
#history .historyBox .year {
	margin-bottom: 1.3rem;
	position: relative;
	font-size: 6.4rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 0.95;
	color: #003893;
}
#history .historyBox .year:last-child {
	margin-bottom: 0;
}
#history .historyBox .left .year {
	text-align: right;
}
#history .historyBox .historyDot {
	position: relative;
}
#history .historyBox .historyDot::before {
	margin-top: 0.2rem;
	width: 1rem;
	height: 1rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: #C8D2DC;
	border-radius: 50%;
	content: '';
}
#history .historyBox .historyDot::after {
	margin-top: 0.2rem;
	width: 10rem;
	height: 0.1rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	border-top: 0.2rem dotted #C8D2DC;
	content: '';
}
#history .historyBox .left .historyDot::before {
	right: -12.15rem;
}
#history .historyBox .left .historyDot::after {
	right: -11.8rem;
}
#history .historyBox .right .historyDot::before {
	left: -11.85rem;
}
#history .historyBox .right .historyDot::after {
	left: -11.4rem;
}
#history .historyBox .historyDot01::before {
	top: 0;
}
#history .historyBox .historyDot01::after {
	margin: 0;
	top: 0.2rem;
}
#history .historyBox .subBox {
	position: relative;
}
#history .historyBox .inner {
	padding: 1rem 0;
	position: relative;
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.575;
	letter-spacing: 0.03em;
	border-top: 1px solid #C8D2DC;
	border-bottom: 1px solid #C8D2DC;
	z-index: 1;
}
#history .historyBox .inner::before {
	width: 5rem;
	height: 1px;
	position: absolute;
	left: 0;
	top: -1px;
	background: #003893;
	content: '';
}
#history .historyBox .inner::after {
	width: 5rem;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: -1px;
	background: #003893;
	content: '';
}
#history .historyBox dl {
	padding: 0.8rem 0;
	display: flex;
	flex-wrap: wrap;
	position: relative;
}
#history .historyBox .dlList02 {
	padding: 0.2rem 0;
}
#history .historyBox .dlList01 dt,
#history .historyBox .dlList02 dt {
	padding-right: 1em;
	min-width: 7rem;
	display: flex;
	align-items: center;
	color: #003893;
	font-size: 2rem;
	font-weight: 500;
	line-height: 1;
}
#history .historyBox .dlList01 dt .num,
#history .historyBox .dlList02 dt .num {
	font-size: 4rem;
	font-weight: 700;
}
#history .historyBox .dlList02 dt .num {
	font-size: 3rem;
}
#history .historyBox .dlList01 dd,
#history .historyBox .dlList02 dd {
	padding-right: 1rem;
	display: flex;
	align-items: center;
	flex: 1;
}
#history .historyBox .dlList02 dd {
	padding-right: 0;
}
#history .historyBox .dlList03 {
	padding: 0;
}
#history .historyBox .dlList03 dt {
	padding: 0.75rem 0;
	width: 5.5rem;
	font-weight: 700;
	color: #003893;
	letter-spacing: 0;
}
#history .historyBox .dlList03 dd {
	padding: 0.75rem 0;
	width: calc(100% - 5.5rem);
	letter-spacing: 0;
}
#history .historyBox .dlList03 dd p {
	margin-right: -1em;
}
#history .historyBox .yearBox01 {
	margin-top: -1.5rem;
}
#history .historyBox .yearBox02 {
	margin: -2.3rem 0 8.8rem;
	padding-left: 14.4rem;
}
#history .historyBox .yearBox03 {
	padding-right: 12rem;
}
#history .historyBox .yearBox03 .dlList01 {
	padding: 0.2rem 0;
}
#history .historyBox .yearBox04 {
	margin-top: -4.7rem;
	padding-right: 31.8rem;
	padding-left: 9.6rem;
}
#history .historyBox .yearBox04 .photo {
	width: 38.2rem;
	margin: -2.1rem 0 0;
	position: absolute;
	left: 0;
	top: 100%;
}
#history .historyBox .yearBox05 {
	margin-top: -3rem;
	margin-bottom: 8.6rem;
}
#history .historyBox .yearBox05 .photo {
	margin: -0.2rem 0 0;
	width: 28.8rem;
	position: absolute;
	right: 0;
	top: 100%;
}
#history .historyBox .yearBox06 {
	margin-bottom: 2.6rem;
	padding-left: 9.8rem;
}
#history .historyBox .yearBox06 .photo {
	margin: -6rem 0 0;
	width: 38.2rem;
	position: absolute;
	left: 0;
	top: 100%;
}
#history .historyBox .yearBox07 {
	margin-bottom: 0.7rem;
}
#history .historyBox .yearBox08 {
	margin-bottom: 3.2rem;
	padding-left: 26rem;
}
#history .historyBox .yearBox08 .dlList01 {
	padding: 0.2rem 0;
}
#history .historyBox .yearBox08 .dlList01 dd p {
	letter-spacing: 0;
	margin-right: -0.5em;
}
#history .historyBox .yearBox09 {
	margin-bottom: 2.3rem;
	padding-left: 18rem;
}
#history .historyBox .yearBox09 .dlList02 {
	padding: 0.7rem 0 0.6rem;
}
#history .historyBox .yearBox10 .historyDot {
	margin-left: 19.8rem;
}
#history .historyBox .yearBox11 {
	margin-top: -4.3rem;
	margin-bottom: 4rem;
	padding-left: 18.1rem;
}
#history .historyBox .yearBox11 .year {
	margin-bottom: 1.6rem;
}
#history .historyBox .yearBox11 .dlList02 {
	padding: 0.7rem 0;
}
#history .historyBox .yearBox12 {
	padding-left: 13.4rem;
}
#history .historyBox .yearBox13 {
	margin-top: -8.2rem;
}
#history .historyBox .yearBox13 .dlList02 {
	padding: 0.7rem 0;
}
#history .historyBox .yearBox13 .photo {
	width: 48rem;
	margin: 1rem -9.6rem 0 auto;
}
#history .historyBox .yearBox14 {
	margin-top: -4.6rem;
	margin-bottom: 2.9rem;
	padding-left: 18rem;
}
#history .historyBox .yearBox15 {
	padding-left: 9.6rem;
}
#history .historyBox .yearBox15 .dlList02 {
	padding: 0.7rem 0;
}
#history .historyBox .yearBox16 {
	margin-top: -6.6rem;
	margin-bottom: 0;
}
#history .historyBox .yearBox16 .photo {
	position: absolute;
	right: 0;
	top: 100%;
	width: 48.1rem;
	margin: 0.9rem 0 0;
}
#history .historyBox .yearBox17 {
	margin-top: -6.2rem;
	padding-left: 9.6rem;
}
#history .historyBox .yearBox17 .photo {
	width: 42.7rem;
	margin: 2rem 0 0 -9.6rem;
}
#history .historyBox .yearBox18 {
	margin-top: -13.9rem;
	margin-bottom: 1.7rem;
	padding-right: 27.2rem;
}
#history .historyBox .yearBox18 .dlList01 {
	padding: 0.2rem 0 0.3rem;
}
#history .historyBox .yearBox18 .dlList01 dd {
	padding-right: 0;
}
#history .historyBox .yearBox19 {
	padding-right: 31.5rem;
	padding-left: 9.6rem;
}
#history .historyBox .yearBox19 .dlList01 dd {
	padding-right: 0;
}
#history .historyBox .yearBox20 {
	margin-top: -14.7rem;
	padding-right: 20.5rem;
}
#history .historyBox .yearBox20 .dlList01 {
	padding: 0.3rem 0;
}
#history .historyBox .last {
	margin-top: -1.8rem;
	position: relative;
}
#history .historyBox .yearBox21 {
	margin: 0;
	width: calc(50% - 20.2rem);
	position: absolute;
	left: 0;
	top: 4.7rem;
}
#history .historyBox .yearBox21 .year {
	margin: 0;
}
#history .historyBox .yearBox21 .historyDot::before {
	display: none;
}
#history .historyBox .last .photo {
	margin: 0 auto;
	width: 40rem;
}
@media all and (min-width: 897px) {
	#history .historyBox .yearBox {
		min-height: 16.3rem;
	}
	#history .historyBox .yearBox01 {
		min-height: 18.8rem;
	}
	#history .historyBox .yearBox02 {
		min-height: 7.7rem;
	}
	#history .historyBox .yearBox03 {
		min-height: 15.1rem;
	}
	#history .historyBox .yearBox04,
	#history .historyBox .yearBox06 {
		min-height: 16.3rem;
	}
	#history .historyBox .yearBox05 {
		min-height: 23.4rem;
	}
	#history .historyBox .yearBox07 {
		min-height: 24.9rem;
	}
	#history .historyBox .yearBox08 {
		min-height: 15.1rem;
	}
	#history .historyBox .yearBox09 {
		min-height: 8.6rem;
	}
	#history .historyBox .yearBox10 {
		min-height: 21.9rem;
	}
	#history .historyBox .yearBox11 {
		min-height: 16.4rem;
	}
	#history .historyBox .yearBox12 {
		min-height: 12.8rem;
	}
	#history .historyBox .yearBox13 {
		min-height: 37.1rem;
	}
	#history .historyBox .yearBox14 {
		min-height: 16.3rem;
	}
	#history .historyBox .yearBox15 {
		min-height: 8.7rem;
	}
	#history .historyBox .yearBox16 {
		min-height: 22.9rem;
	}
	#history .historyBox .yearBox17 {
		min-height: 58.8rem;
	}
	#history .historyBox .yearBox18 {
		min-height: 15.2rem;
	}
	#history .historyBox .yearBox19 {
		min-height: 18.8rem;
	}
	#history .historyBox .yearBox20 {
		min-height: 14.2rem;
	}
}
@media all and (min-width: 897px) and (max-width: 1535px) {
	#history .historyBox .inner {
		padding: 0.9rem 0;
	}
	#history .historyBox .dlList01 dd,
	#history .historyBox .dlList02 dd {
		padding-right: 0;
	}
}
@media all and (min-width: 897px) and (max-width: 1065px) {
	#history .historyBox .yearBox19 {
		padding-left: 9.2rem;
	}
}
@media all and (max-width: 896px) {
	#history .mainBox {
		margin-bottom: 100px;
		padding-top: 126px;
	}
	#history .mainBox .content {
		margin: 0;
		padding: 49px 25px 100px;
	}
	#history .mainBox .headLine01 {
		margin-bottom: 54px;
	}
	#history .mainBox .innerWrap {
		margin: 0;
		padding: 49px 20px 0;
	}
	#history .mainBox .photo01 {
		width: 160px;
	}
	#history .mainBox h4 {
		margin-bottom: 22px;
		font-size: 1rem;
	}
	#history .mainBox h4 span {
		padding-bottom: 0;
	}
	#history .historyBox .boxInner {
		padding: 0 0 21px 35px;
		min-height: initial;
		background: none;
		position: relative;
	}
	#history .historyBox .boxInner::before {
		width: 1px;
		position: absolute;
		left: 0.4rem;
		top: 20px;
		bottom: -20px;
		background: #003893;
		content: '';
		z-index: 1;
	}
	#history .historyBox .spBg {
		width: 33px;
		top: 71px;
		bottom: 10px;
		position: absolute;
		right: 0;
		background: rgba(0, 56, 147, 0.1);
		content: '';
	}
	#history .historyBox .spBg::before {
		width: 53px;
		height: 72px;
		position: absolute;
		left: -10px;
		top: -72px;
		background: url(img/company/history/bg01_sp.png) no-repeat center bottom / 100%;
		content: '';
		z-index: 1;
	}
	#history .historyBox .spBg::after {
		width: 33px;
		height: 50px;
		position: absolute;
		left: 0;
		bottom: -50px;
		background: url(img/company/history/bg02_sp.png) no-repeat center bottom / 100%;
		content: '';
		z-index: 1;
	}
	#history .historyBox .yearBox {
		margin: 0 0 24px !important;
		padding: 0 !important;
		width: auto;
	}
	#history .historyBox .yearBox:last-child {
		margin-bottom: 0 !important;
	}
	#history .historyBox .year {
		margin-bottom: 4px !important;
		text-align: left !important;
		font-size: 3.2rem;
		line-height: 1.25;
	}
	#history .historyBox .year:last-child {
		margin-bottom: 0 !important;
	}
	#history .historyBox .historyDot::before {
		left: -35px !important;
		right: auto !important;
		background: #003893;
	}
	#history .historyBox .historyDot::after {
		margin: 3px 0 0;
		width: 27px;
		left: -32px !important;
		right: auto !important;
		border-top: 1px dotted #003893;
	}
	#history .historyBox .historyDot01::before {
		top: 20px;
	}
	#history .historyBox .historyDot01::after {
		top: 20px;
	}
	#history .historyBox .historyDot02::before {
		top: 20px;
	}
	#history .historyBox .historyDot02::after {
		top: 20px;
	}
	#history .historyBox .inner {
		padding: 11px 0 10px;
		font-size: 1.4rem;
		line-height: 1.4;
	}
	#history .historyBox .inner::before {
		width: 25px;
	}
	#history .historyBox .inner::after {
		width: 25px;
	}
	#history .historyBox dl {
		padding: 0 !important;
	}
	#history .historyBox dt {
		margin-bottom: 9px !important;
	}
	#history .historyBox .dlList01,
	#history .historyBox .dlList02 {
		padding: 0;
		display: block;
	}
	#history .historyBox .dlList01 dt,
	#history .historyBox .dlList02 dt {
		padding-right: 0;
		min-width: initial !important;
		display: block;
		font-size: 1rem;
	}
	#history .historyBox .dlList01 dt .num,
	#history .historyBox .dlList02 dt .num {
		font-size: 2rem;
	}
	#history .historyBox .dlList02 dt .num {
		font-size: 2rem;
	}
	#history .historyBox .dlList01 dd,
	#history .historyBox .dlList02 dd {
		padding-right: 0;
		display: block;
	}
	#history .historyBox .dlList03 {
		font-size: 1rem;
	}
	#history .historyBox .dlList03 dt {
		margin-bottom: 0 !important;
		padding: 0 0 11px;
		width: 3.5rem;
	}
	#history .historyBox .dlList03 dd {
		padding: 0 0 11px;
		width: calc(100% - 3.5rem);
	}
	#history .historyBox .dlList03 dt:last-of-type {
		padding-bottom: 0;
	}
	#history .historyBox .dlList03 dd:last-of-type {
		padding-bottom: 0;
	}
	#history .historyBox .dlList03 dd p {
		margin-right: 0 !important;
	}
	#history .historyBox .yearBox .photo {
		width: 160px !important;
	}
	#history .historyBox .yearBox04 .photo {
		margin: -17px 0 -25px -56px;
		position: static;
		width: 165px !important;
	}
	#history .historyBox .yearBox05 .photo {
		margin: -36px -20px -30px auto;
		width: 160px !important;
		position: static;
	}
	#history .historyBox .yearBox06 .photo {
		margin: -20px 0 -30px -56px;
		position: static;
	}
	#history .historyBox .yearBox08 .dlList01 {
		padding: 0;
	}
	#history .historyBox .yearBox08 .dlList01 dd p {
		margin-right: 0;
	}
	#history .historyBox .yearBox09 .dlList02 {
		padding: 0;
	}
	#history .historyBox .yearBox10 .historyDot {
		margin-left: 0;
	}
	#history .historyBox .yearBox10 .historyDot::after {
		display: block;
	}
	#history .historyBox .yearBox11 .dlList02 {
		padding: 0;
	}
	#history .historyBox .yearBox13 .dlList02 {
		padding: 0;
	}
	#history .historyBox .yearBox13 .photo {
		margin: -10px -20px -30px auto;
	}
	#history .historyBox .yearBox15 .dlList02 {
		padding: 0;
	}
	#history .historyBox .yearBox16 .photo {
		position: static;
		margin: -5px -20px -30px auto;
	}
	#history .historyBox .yearBox17 .photo {
		margin: -10px 0 -30px -56px;
	}
	#history .historyBox .last {
		margin-top: 0;
	}
	#history .historyBox .yearBox21 {
		margin: 0 0 0 35px !important;
		width: auto;
		position: relative;
		left: auto;
		top: auto;
	}
	#history .historyBox .yearBox21 .historyDot::before {
		display: block;
	}
	#history .historyBox .last .photo {
		margin: -1px -7px 0 0;
		width: auto;
		text-align: right;
	}
	#history .historyBox .last .photo img {
		width: 250px;
	}
}
/*------------------------------------------------------------
	manufacture
------------------------------------------------------------*/
#manufacture .secBox {
	margin-bottom: 200px;
	position: relative;
}
#manufacture .secBox .headLine01 {
	margin-bottom: 105px;
}
#manufacture .secBox .content {
	padding: 200px 0 100px;
	background: #EFF5F8;
}
#manufacture .technique {
	padding-top: 200px;
}
#manufacture .technique .comParallax {
	height: 640px;
}
#manufacture .technique .content {
	padding-bottom: 200px;
}
#manufacture .technique .comNavBox {
	margin-bottom: 520px;
}
#manufacture .technique .comNavBox .img {
	margin-top: 17px;
	right: auto;
	left: -191px;
}
@media all and (max-width: 1536px) {
	#manufacture .quality .comNavBox .img {
		right: -11%;
	}
	#manufacture .technique .comNavBox .img {
		left: -11%;
	}
}
@media all and (max-width: 1280px) {
	#manufacture .quality .comNavBox .img {
		right: -4.5%;
	}
	#manufacture .technique .comNavBox .img {
		left: -5%;
	}
}
@media all and (max-width: 896px) {
	#manufacture .secBox {
		margin-bottom: 0;
	}
	#manufacture .secBox .headLine01 {
		margin-bottom: 54px;
	}
	#manufacture .secBox .content {
		margin: 0;
		padding: 49px 25px;
	}
	#manufacture .quality .comNavBox .img {
		right: 0;
	}
	#manufacture .technique {
		padding-top: 350px;
	}
	#manufacture .technique .comParallax {
		height: 350px;
	}
	#manufacture .technique .content {
		padding-bottom: 100px;
	}
	#manufacture .technique .comNavBox {
		margin-bottom: 65px;
	}
	#manufacture .technique .comNavBox .img {
		margin: -27px 0 0;
		right: auto;
		left: auto;
	}
	#manufacture .comNavBox .navList li a {
		padding-left: 3em;
		text-indent: -3em;
	}
}
/*------------------------------------------------------------
	product
------------------------------------------------------------*/
#product .comPrimary {
	padding-bottom: 413px;
}
#product .comNavBox {
	margin-bottom: 291px;
}
#product .comNavBox .img {
	margin-top: -17.5rem;
	right: auto;
	left: -108px;
	width: 30rem;
}
#product .sec01 {
	margin-bottom: 200px;
	position: relative;
	z-index: 1;
}
#product .sec01 .content {
	padding: 200px 0;
	background: #EFF5F8;
}
#product .sec01 .subSec .img {
	padding: 100px 0;
	background: #FFF;
}
#product .sec02 {
	margin-bottom: 200px;
	padding-bottom: 194px;
	position: relative;
	background: #EFF5F8;
}
#product .sec02 .comParallax {
	height: 102rem;
	top: -60.1rem;
	z-index: 0;
}
#product .sec02 .headLine02 {
	color: #fff;
}
#product .sec02 .imgList {
	display: flex;
	flex-wrap: wrap;
	gap: 50px 3.2%;
}
#product .sec02 .imgList li {
	width: 22.6%;
}
#product .sec02 .imgList li .photo {
	margin-bottom: 30px;
}
#product .sec02 .imgList li .photo img {
	width: 100%;
}
#product .sec02 .imgList li h5 {
	margin-bottom: 8px;
	color: #003893;
	font-size: 3rem;
	font-weight: 500;
	letter-spacing: 0.12em;
}
#product .sec02 .imgList li p {
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.8125;
}
#product .sec02 .imgList li:nth-child(4n-2) {
	padding-top: 110px;
}
#product .sec02 .imgList li:nth-child(4n-1) {
	padding-top: 200px;
}
#product .sec03 {
	margin-bottom: 200px;
}
#product .sec03 .headLine02 {
	margin-bottom: 53px;
}
#product .sec03 .text01 {
	margin-bottom: 22px;
	text-align: center;
	font-size: 2rem;
	letter-spacing: 0.03em;
}
#product .sec03 .text02 {
	margin-bottom: 77px;
	text-align: center;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.8125;
}
#product .sec03 .btnList {
	margin: 0 auto;
	max-width: 1152px;
	display: flex;
	justify-content: space-between;
}
#product .sec03 .btnList li {
	width: 45.7%;
}
#product .sec03 .btnList li a {
	padding: 42px 20px 40px;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	text-align: center;
	color: #fff;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	border-radius: 10px;
	background: #003893;
}
#product .sec03 .btnList li a span {
	position: relative;
	z-index: 1;
}
#product .sec03 .btnList li a .tel {
	display: block;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.06em;
}
#product .sec03 .btnList li a .tel span {
	margin-left: 10px;
	font-size: 3.4rem;
	letter-spacing: 0.1em;
}
#product .sec03 .btnList .cta a::before {
	width: 0;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	border-radius: inherit;
	background: #001D4D;
	transition: 0.3s;
	content: '';
}
#product .sec03 .btnList .cta a::after {
	width: 11px;
	height: 11px;
	position: absolute;
	right: 25px;
	top: 50%;
	transform: translateY(-50%);
	background: url(img/common/icon01.png) no-repeat center center;
	background-size: 11px;
	content: '';
	z-index: 1;
}
@media all and (max-width: 1536px) {
	#product .comNavBox .img {
		left: -8%;
		margin-top: -14rem;
	}
}
@media all and (min-width: 897px) {
	#product .sec03 .btnList .cta a:hover:before {
		width: 100%;
	}
}
@media all and (max-width: 896px) {
	#product .comPrimary {
		padding-bottom: 179px;
	}
	#product .comNavBox {
		margin-bottom: 56px;
	}
	#product .comNavBox .img {
		margin: -53px 3px 0;
		right: auto;
		left: auto;
		width: 150px;
	}
	#product .sec01 {
		margin-bottom: 0;
	}
	#product .sec01 .content {
		margin: 0;
		padding: 50px 0;
	}
	#product .sec01 .content .innerWrap {
		margin: 0 25px;
	}
	#product .sec01 .headLine01 {
		margin-bottom: 50px;
	}
	#product .sec01 .headLine01 .txt {
		margin-bottom: 11px;
	}
	#product .sec01 .headLine01 .en {
		line-height: 1.22;
	}
	#product .headLine02 {
		margin: 0 0 14px;
	}
	#product .sec01 .subSec .img {
		padding: 25px;
		text-align: center;
	}
	#product .sec02 {
		margin-bottom: 50px;
		padding-top: 200px;
		padding-bottom: 46px;
	}
	#product .sec02 .comParallax {
		height: 355px;
		top: 0;
	}
	#product .sec02 .imgList {
		gap: 47px 0;
		justify-content: space-between;
	}
	#product .sec02 .imgList li {
		width: 45.8%;
	}
	#product .sec02 .imgList li .photo {
		margin-bottom: 15px;
	}
	#product .sec02 .imgList li h5 {
		margin-bottom: 5px;
		font-size: 1.6rem;
	}
	#product .sec02 .imgList li p {
		font-size: 1.6rem;
	}
	#product .sec02 .imgList li:nth-child(4n-2) {
		padding-top: 0;
	}
	#product .sec02 .imgList li:nth-child(4n-1) {
		padding-top: 0;
	}
	#product .sec03 {
		margin-bottom: 100px;
	}
	#product .sec03 .headLine02 {
		margin-bottom: 22px;
	}
	#product .sec03 .text01 {
		margin-bottom: 6px;
		text-align: left;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#product .sec03 .text02 {
		margin-bottom: 38px;
		text-align: left;
		font-size: 1rem;
	}
	#product .sec03 .btnList {
		width: 84.4%;
		max-width: initial;
		display: block;
	}
	#product .sec03 .btnList li {
		margin-bottom: 25px;
		width: auto;
	}
	#product .sec03 .btnList li a {
		padding: 10px 25px 8px;
		min-height: 60px;
		font-size: 1.4rem;
		line-height: 1.36;
		border-radius: 5px;
		background: #003893 url(img/common/icon08.png) no-repeat right 15px center / 7px;
	}
	#product .sec03 .btnList li a .tel {
		font-size: 1rem;
	}
	#product .sec03 .btnList li a .tel span {
		font-size: 1.7rem;
		font-weight: 700;
	}
	#product .sec03 .btnList .cta a::after {
		background-image: url(img/common/icon08.png);
		background-position: right 15px center;
		background-size: 7px;
	}
}
@media all and (max-width: 374px) {
	#product .sec02 .imgList li h5 {
		letter-spacing: 0.05em;
	}
}
/*------------------------------------------------------------
	recruit
------------------------------------------------------------*/
#recruit {
	margin-bottom: 200px;
}
#recruit .lightBlue {
	background: #EFF5F8;
}
#recruit .comPrimary {
	padding-bottom: 333px;
}
#recruit .anchorList {
	margin-bottom: 209px;
	justify-content: flex-end;
	gap: 30px;
}
#recruit .anchorList li {
	min-width: 150px;
}
#recruit .anchorList li a {
	padding: 0 15px 3px 15px;
	display: block;
	position: relative;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
}
#recruit .anchorList li a::before {
	width: 100%;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: 0;
	background: #003893;
	content: '';
}
#recruit .anchorList li a::after {
	width: 0;
	height: 1px;
	position: absolute;
	left: 0;
	bottom: 0;
	background: #fff;
	z-index: 1;
	transition: 0.3s;
	content: '';
}
#recruit .anchorList li a span {
	padding: 0 35px 1px 12px;
	display: block;
	position: relative;
}
#recruit .anchorList li a span::before {
	width: 6px;
	height: 6px;
	position: absolute;
	left: 0;
	top: 0.75em;
	background: #003893;
	border-radius: 50%;
	transform: translateY(-50%);
	content: '';
}
#recruit .anchorList li a span::after {
	content: '';
	width: 0.8rem;
	height: 0.7rem;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	background: url(img/common/icon11.png) no-repeat center center / 100%;
	transition: 0.3s;
}
#recruit .sec01 .lightBlue {
	padding: 46px 50px 288px;
}
#recruit .sec01 .comNavBox {
	margin-bottom: 0;
}
#recruit .sec01 .comNavBox .img {
	width: 200px;
	margin: -221px 0 0 auto;
	position: static;
}
#recruit .h4Ttl {
	margin-bottom: 28px;
	color: #003893;
	font-size: 4rem;
	font-weight: 500;
	letter-spacing: 0.1em;
}
#recruit .h4Ttl .en {
	margin-bottom: 6px;
	display: block;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.05em;
}
#recruit .subSec {
	padding: 1px 0 500px;
	display: flex;
	justify-content: space-between;
	color: #fff;
	background: #003893;
	position: relative;
	z-index: 1;
}
#recruit .subSec .textBox {
	width: 44.6%;
	display: flex;
	align-items: center;
	padding-top: 47px;
}
#recruit .subSec .textBox .innerBox {
	margin-left: auto;
	width: 470px;
	max-width: 90%;
}
#recruit .subSec .textBox .h4Ttl {
	color: #fff;
}
#recruit .subSec .textBox p {
	margin-bottom: 40px;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.6875;
}
#recruit .subSec .textBox .sm {
	font-size: 1.1rem;
}
#recruit .subSec .textBox p:last-child {
	margin-bottom: 0;
}
#recruit .subSec .photoBox {
	margin-top: -101px;
	width: 50%;
}
#recruit .subSec .photoBox img {
	width: 100%;
}
#recruit .subSec02 {
	padding-bottom: 200px;
	color: #1E1E1E;
	flex-direction: row-reverse;
	background: #fff;
}
#recruit .subSec02 .textBox {
	padding-top: 103px;
}
#recruit .subSec02 .textBox .innerBox {
	margin: 0;
}
#recruit .subSec02 .textBox .h4Ttl {
	color: #003893;
}
#recruit .subSec03 {
	padding-top: 199px;
	background: #F2F4F6;
}
#recruit .subSec03 .ttlBox {
	margin-bottom: 71px;
	display: flex;
}
#recruit .subSec03 .ttlBox .h4Ttl {
	flex: 1;
}
#recruit .subSec03 .ttlBox p {
	width: 62.3%;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.03em;
}
#recruit .subSec03 .subBox {
	padding-bottom: 400px;
	position: relative;
}
#recruit .subSec03 .subBox::before {
	width: 100%;
	height: calc(100% - 46.8rem);
	position: absolute;
	left: 0;
	bottom: 0;
	background: #003893;
	content: '';
}
#recruit .subSec03 .imgList {
	display: flex;
	flex-wrap: wrap;
	gap: 0 6.275%;
	position: relative;
	z-index: 1;
}
#recruit .subSec03 .imgList li {
	width: 29.15%;
}
#recruit .subSec03 .imgList li:nth-child(3n-1) {
	padding-top: 15rem;
}
#recruit .subSec03 .imgList li .photo img {
	width: 100%;
}
#recruit .subSec03 .imgList li .photo {
	margin-bottom: 10px;
}
#recruit .subSec03 .imgList li p {
	font-size: 1.1rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	color: #fff;
}
#recruit .subSec03 .subBox .text {
	width: 100%;
	position: absolute;
	left: 50%;
	top: 38.8rem;
	text-align: center;
	font-size: 15.7rem;
	font-weight: 200;
	letter-spacing: 0.03em;
	line-height: 1;
	color: #F4F7F8;
	mix-blend-mode: overlay;
	word-break: keep-all;
	white-space: nowrap;
	transform: translateX(-50%);
	z-index: 2;
}
#recruit .sec02 {
	padding: 400px 0;
	position: relative;
}
#recruit .sec02 .content {
	padding: 200px 0;
}
#recruit .sec02 .comNavBox {
	margin-bottom: 389px;
}
#recruit .sec02 .comNavBox .img {
	width: 400px;
	margin: -219px -9.6rem 0 auto;
	position: static;
}
#recruit .sec02 .comImgList li {
	margin-bottom: 198px;
}
#recruit .sec02 .comImgList li:last-child {
	margin-bottom: 0;
}
#recruit .sec02 .comImgList li:nth-child(2n-1) .h4Ttl {
	width: calc(50% - 96px);
	margin-left: auto;
}
#recruit .sec02 .comImgList li .imgBox .textBox {
	padding: 100px 0;
}
#recruit .sec03 {
	margin-bottom: 200px;
	padding-top: 400px;
	position: relative;
}
#recruit .sec03 .content {
	padding: 198px 0 267px;
}
#recruit .sec03 .comNavBox {
	margin-bottom: 0;
}
#recruit .sec03 .comNavBox .img {
	width: 230px;
	margin: -220px 0 0 auto;
	position: static;
}
#recruit .sec03 .subSec .textBox {
	padding-top: 73px;
}
#recruit .sec03 .subSec02 {
	padding-bottom: 98px;
}
#recruit .sec03 .subSec02 .textBox {
	padding-top: 20px;
}
#recruit .sec03 .subSec02 .h4Ttl .en {
	margin-right: -70px;
}
#recruit .sec03 .work {
	padding: 100px 0;
}
#recruit .sec03 .work .ttlBox {
	margin-bottom: 48px;
	display: flex;
	justify-content: space-between;
}
#recruit .sec03 .work .ttlBox h5 {
	width: 50%;
	color: #5A5A5A;
	font-size: 3rem;
	font-weight: 500;
	letter-spacing: 0.03em;
}
#recruit .sec03 .work .ttlBox h5 .en {
	margin-top: 3px;
	display: block;
	color: #C8D2DC;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.05em;
}
#recruit .sec03 .work .ttlBox p {
	margin-top: 1px;
	width: 50%;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.8;
}
#recruit .sec03 .work .ttlBox p .note {
	margin-top: 0.5em;
	display: block;
	color: #1C1C1C;
	font-size: 1.1rem;
}
#recruit .sec03 .work .img {
	margin: 0 -2px;
	text-align: center;
}
#recruit .sec03 .subSec03 {
	margin: 0;
	padding-top: 398px;
	position: relative;
	background: transparent;
}
#recruit .sec03 .subSec03::before {
	width: 100%;
	left: 0;
	top: -100px;
	bottom: 22.7rem;
	position: absolute;
	background: #003893;
	content: '';
}
#recruit .sec03 .subSec03 .subWrap {
	position: relative;
	z-index: 1;
}
#recruit .sec03 .subSec03 .ttlBox {
	margin-bottom: 130px;
	color: #fff;
}
#recruit .sec03 .subSec03 .ttlBox .h4Ttl {
	color: #fff;
}
#recruit .sec03 .subSec03 .ttlBox p {
	margin-top: 1px;
	width: 41.5%;
	font-weight: 400;
	line-height: 1.71;
}
#recruit .sec03 .subSec03 .ttlBox p .note {
	display: block;
	font-size: 1.1rem;
	margin-top: 10px;
	letter-spacing: 0.03em;
}
#recruit .sec03 .subSec03 .photo {
	margin-bottom: 10px;
}
#recruit .sec03 .subSec03 .figcaption {
	color: #1C1C1C;
	font-size: 1.1rem;
	font-weight: 400;
	letter-spacing: 0.03em;
}
#recruit .telBox {
	padding: 100px 0;
}
#recruit .telBox .innerWrap {
	padding: 100px 0;
	text-align: center;
	background: #fff;
}
#recruit .telBox p {
	margin-bottom: 42px;
	font-weight: 400;
	letter-spacing: 0.03em;
}
#recruit .telBox .tel {
	margin-bottom: 12px;
	color: #707070;
	font-size: 3rem;
	font-weight: 200;
	letter-spacing: 0;
}
#recruit .telBox .tel a {
	margin-left: 10px;
	font-size: 6rem;
}
#recruit .telBox p:last-child {
	margin-bottom: 0;
}
@media all and (min-width: 897px) and (max-width: 1880px) {
	#recruit .subSec03 .subBox .text {
		font-size: 8.351vw;
	}
}
@media all and (min-width: 897px) {
	#recruit .anchorList li a:hover::after {
		width: 100%;
	}
	#recruit .anchorList li a:hover span::after {
		top: calc(50% + 0.5rem);
	}
}
@media all and (max-width: 896px) {
	#recruit {
		margin-bottom: 100px;
	}
	#recruit .comPrimary {
		padding-bottom: 208px;
	}
	#recruit .anchorList {
		margin: 0 -5px 64px;
		flex-wrap: wrap;
		justify-content: center;
		gap: 12px;
	}
	#recruit .anchorList li {
		min-width: initial;
	}
	#recruit .anchorList li a {
		padding: 0 0 3px;
		font-size: 1.2rem;
		letter-spacing: 0;
	}
	#recruit .anchorList li a span {
		padding: 0 22px 0 10px;
	}
	#recruit .anchorList li a span::before {
		width: 5px;
		height: 5px;
	}
	#recruit .anchorList li a span::after {
		width: 0.7rem;
		height: 0.6rem;
		background-image: url(img/common/icon12.png);
	}
	#recruit .sec01 .lightBlue {
		margin: 0;
		padding: 47px 25px 15px;
	}
	#recruit .sec01 .comNavBox .navList {
		margin-bottom: 13px;
	}
	#recruit .sec01 .comNavBox .img {
		width: 70px;
		margin: 0 0 0 auto;
	}
	#recruit .h4Ttl {
		margin-bottom: 11px;
		font-size: 1.9rem;
		letter-spacing: 0;
	}
	#recruit .h4Ttl .en {
		margin-bottom: 4px;
		font-size: 0.7rem;
		font-weight: 500;
	}
	#recruit .subSec {
		padding: 50px 25px 100px;
		display: block;
	}
	#recruit .subSec .textBox {
		margin-bottom: 23px;
		width: auto;
		display: block;
		padding-top: 0;
	}
	#recruit .subSec .textBox .innerBox {
		margin-left: 0;
		width: auto;
		max-width: initial;
	}
	#recruit .subSec .textBox p {
		margin-bottom: 12px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#recruit .subSec .textBox .sm {
		font-size: 1rem;
	}
	#recruit .subSec .textBox p:last-child {
		margin-bottom: 0;
	}
	#recruit .subSec .photoBox {
		margin-top: 0;
		width: auto;
	}
	#recruit .subSec02 {
		padding-bottom: 100px;
	}
	#recruit .subSec02 .textBox {
		padding-top: 0;
	}
	#recruit .subSec03 {
		padding-top: 50px;
	}
	#recruit .subSec03 .ttlBox {
		margin-bottom: 22px;
		display: block;
	}
	#recruit .subSec03 .ttlBox p {
		width: auto;
		font-size: 1.6rem;
	}
	#recruit .subSec03 .subBox {
		padding-bottom: 100px;
	}
	#recruit .subSec03 .subBox::before {
		height: calc(100% - 11rem);
	}
	#recruit .subSec03 .imgList {
		justify-content: space-between;
		gap: 0;
	}
	#recruit .subSec03 .imgList li {
		width: calc(50% - 5px);
	}
	#recruit .subSec03 .imgList li:nth-child(3n-1) {
		padding-top: 13.7rem;
	}
	#recruit .subSec03 .imgList li:nth-child(3n) {
		margin-top: -9.1rem;
	}
	#recruit .subSec03 .imgList li .photo {
		margin-bottom: 7px;
	}
	#recruit .subSec03 .imgList li p {
		font-size: 1rem;
		line-height: 1.2;
	}
	#recruit .subSec03 .subBox .text {
		display: none;
	}
	#recruit .sec02 {
		padding: 350px 0 0;
	}
	#recruit .sec02 .comParallax {
		height: 350px;
	}
	#recruit .sec02 .content {
		margin: 0;
		padding: 50px 25px;
	}
	#recruit .sec02 .comNavBox {
		margin-bottom: 0;
	}
	#recruit .sec02 .comNavBox .navList {
		margin-bottom: 0;
	}
	#recruit .sec02 .comNavBox .img {
		width: 183px;
		margin: -13px -2.5rem -2rem auto;
		position: static;
	}
	#recruit .sec02 .comImgList li {
		margin-bottom: 100px;
	}
	#recruit .sec02 .comImgList li:last-child {
		margin-bottom: 0;
	}
	#recruit .sec02 .comImgList li .h4Ttl {
		margin-bottom: 13px;
	}
	#recruit .sec02 .comImgList li:nth-child(2n-1) .h4Ttl {
		width: auto;
		margin-left: 0;
	}
	#recruit .sec02 .comImgList li .imgBox .textBox {
		padding: 14px 24px 23px;
	}
	#recruit .sec03 {
		margin-bottom: 50px;
		padding-top: 350px;
	}
	#recruit .sec03 .comParallax {
		height: 350px;
	}
	#recruit .sec03 .content {
		margin: 0;
		padding: 50px 25px 28px;
	}
	#recruit .sec03 .headLine01 {
		margin-bottom: 50px;
	}
	#recruit .sec03 .headLine01 .txt {
		margin-bottom: 11px;
	}
	#recruit .sec03 .headLine01 .en {
		line-height: 1.2;
	}
	#recruit .sec03 .comNavBox .img {
		width: 115px;
		margin: -124px 0 0 auto;
	}
	#recruit .sec03 .subSec .textBox {
		padding-top: 0;
		margin-bottom: 27px;
	}
	#recruit .sec03 .subSec01 {
		padding-bottom: 50px;
	}
	#recruit .sec03 .subSec02 {
		padding-bottom: 50px;
	}
	#recruit .sec03 .subSec02 .textBox {
		padding-top: 0;
	}
	#recruit .sec03 .subSec02 .h4Ttl .en {
		margin-right: 0;
	}
	#recruit .sec03 .work {
		padding: 50px 25px;
	}
	#recruit .sec03 .work .ttlBox {
		margin-bottom: 23px;
		display: block;
	}
	#recruit .sec03 .work .ttlBox h5 {
		margin-bottom: 10px;
		width: auto;
		font-size: 1.6rem;
		letter-spacing: 0;
	}
	#recruit .sec03 .work .ttlBox h5 .en {
		font-size: 0.9rem;
		font-weight: 500;
		letter-spacing: 0.03em;
	}
	#recruit .sec03 .work .ttlBox p {
		margin-top: 0;
		width: auto;
		font-size: 1.6rem;
	}
	#recruit .sec03 .work .ttlBox p .note {
		margin-top: 1px;
		color: #1E1E1E;
		font-size: 1rem;
		letter-spacing: 0.03em;
	}
	#recruit .sec03 .work .img {
		margin: 0;
		text-align: center;
	}
	#recruit .sec03 .subSec03 {
		margin: 0;
		padding: 50px 25px;
		background: #003893;
	}
	#recruit .sec03 .subSec03::before {
		display: none;
	}
	#recruit .sec03 .subSec03 .ttlBox {
		margin-bottom: 22px;
	}
	#recruit .sec03 .subSec03 .ttlBox p {
		margin-top: 0;
		width: auto;
		line-height: 1.8;
	}
	#recruit .sec03 .subSec03 .ttlBox p .note {
		font-size: 1rem;
		margin-top: 1px;
	}
	#recruit .sec03 .subSec03 .photo {
		margin-bottom: 5px;
	}
	#recruit .sec03 .subSec03 .photo img {
		width: 100%;
	}
	#recruit .sec03 .subSec03 .figcaption {
		color: #fff;
		font-size: 1rem;
	}
	#recruit .telBox {
		margin: 0;
		padding: 50px 0;
	}
	#recruit .telBox .innerWrap {
		margin: 0 25px;
		padding: 22px 0;
	}
	#recruit .telBox p {
		margin-bottom: 19px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#recruit .telBox .tel {
		margin-bottom: 22px;
		font-size: 1.5rem;
	}
	#recruit .telBox .tel a {
		margin-left: 0;
		font-size: 3.5rem;
		line-height: 1.32;
	}
	#recruit .telBox p:last-child {
		margin-bottom: 0;
	}
	#recruit .telBox .time {
		font-size: 1rem;
	}
}
/*------------------------------------------------------------
	contact
------------------------------------------------------------*/
#contact .mainBox {
	margin-bottom: 200px;
	padding-top: 200px;
	position: relative;
}
#contact .mainBox .content {
	padding: 191px 0 200px;
	background: #EFF5F8;
}
#contact .topText {
	margin-bottom: 41px;
	font-size: 2rem;
	letter-spacing: 0.03em;
	line-height: 2.4;
}
#contact .bgWhite {
	padding: 100px 0;
	background: #fff;
}
#contact .telBox {
	margin-bottom: 136px;
	text-align: center;
	font-weight: 400;
	letter-spacing: 0.03em;
}
#contact .telBox p {
	margin-bottom: 58px;
}
#contact .telBox .tel {
	margin-bottom: 27px;
	color: #707070;
	font-weight: 200;
	font-size: 3rem;
	letter-spacing: 0;
	line-height: 1;
}
#contact .telBox .tel a {
	margin-left: 10px;
	vertical-align: -1px;
	font-size: 6rem;
}
#contact .telBox p:last-child {
	margin-bottom: 0;
}
#contact .mailForm {
	padding-top: 90px;
}
#contact .mailForm .headLine01 {
	margin-bottom: 173px;
}
#contact .mailForm table {
	margin-bottom: 40px;
	width: 100%;
	border-collapse: collapse;
}
#contact .mailForm th,
#contact .mailForm td {
	padding: 0 0 40px;
	text-align: left;
	vertical-align: top;
	font-weight: 400;
	letter-spacing: 0.03em;
	box-sizing: border-box;
	word-break: break-all;
}
#contact .mailForm tr:last-child th,
#contact .mailForm tr:last-child td {
	padding: 0;
}
#contact .mailForm th {
	width: 16.7%;
}
#contact .mailForm th .must {
	margin-top: 5px;
	display: block;
	color: #FF0000;
	font-size: 1rem;
	font-weight: 500;
}
#contact .mailForm .radioList {
	margin-bottom: 59px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 49px;
}
#contact .mailForm .radioList span {
	margin: 0;
}
#contact .mailForm .radioList .wpcf7-radio {
	display: flex;
	flex-wrap: wrap;
	gap: 10px 49px;
}
#contact .mailForm .radioList label {
	display: inline-block;
	font-size: 1.4rem;
	font-weight: 500;
}
#contact .mailForm .radioList input[type="radio"] {
	display: none;
}
#contact .mailForm .radioList input[type="radio"] ~ span {
	padding: 1px 0 0 25px;
	display: inline-block;
	vertical-align: top;
	background: url(img/contact/radio01.png) no-repeat left center / 20px;
	cursor: pointer;
}
#contact .mailForm .radioList input[type="radio"]:checked ~ span {
	background-image: url(img/contact/radio02.png);
}
#contact .mailForm input[type="text"],
#contact .mailForm input[type="tel"],
#contact .mailForm input[type="email"],
#contact .mailForm textarea {
	padding: 19px 29px;
	width: 100%;
	height: 80px;
	vertical-align: top;
	color: #1E1E1E;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.03em;
	border-radius: 8px;
	border: 1px solid #C8C8C8;
	background: #fff;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
}
#contact .mailForm textarea {
	height: 300px;
	resize: vertical;
}
#contact .mailForm ::placeholder {
	opacity: 0.4;
	color: #1E1E1E;
}
#contact .mailForm .nameBox {
	display: flex;
	justify-content: space-between;
}
#contact .mailForm .nameBox .first,
#contact .mailForm .nameBox .last {
	width: 47.9%;
}
#contact .mailForm .privacy {
	margin-bottom: 100px;
	text-align: center;
	font-weight: 400;
	letter-spacing: 0.03em;
}
#contact .mailForm .privacy a {
	font-weight: 700;
	color: #003893;
	text-decoration: underline;
}
#contact .mailForm .privacy a:hover {
	opacity: 0.7;
}
#contact .mailForm .submit {
	margin: 0 auto;
	max-width: 788px;
	display: flex;
	justify-content: center;
	gap: 20px;
}
#contact .mailForm .submit li {
	width: calc(50% - 10px);
}
#contact .mailForm .submit input {
	padding: 10px 40px;
	width: 100%;
	height: 80px;
	color: #fff;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 500;
	letter-spacing: 0.2em;
	border-radius: 10px;
	border: none;
	background: #003893 url(img/common/icon01.png) no-repeat right 29px center / 11px;
	box-sizing: border-box;
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	transition: 0.3s;
}
#contact .mailForm .submit .retry input {
	background: #C8C8C8 url(img/common/icon03.png) no-repeat left 29px center / 11px;
}
#contact .confirm .headLine01 {
	margin-bottom: 97px;
}
#contact .confirm table {
	margin-bottom: 109px;
}
#contact .confirm th,
#contact .confirm td {
	padding-bottom: 21px;
	line-height: 1.81;
}
#contact .confirm td {
	font-weight: 500;
}
#contact .thanks .headLine01 {
	margin-bottom: 46px;
}
#contact .thanks p {
	line-height: 1.8;
	letter-spacing: 0.03em;
}
#contact .mailForm .headLine01 .jp {
	display: none;
}
#contact .mailForm.confirm .headLine01 .jp,
#contact .mailForm.thanks .headLine01 .jp {
	display: block;
}
@media all and (min-width: 897px) {
	#contact .mailForm .submit input:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#contact .mainBox {
		margin-bottom: 50px;
		padding-top: 126px;
	}
	#contact .mainBox .content {
		margin: 0;
		padding: 40px 0 50px;
	}
	#contact .content .innerWrap {
		margin: 0 25px;
	}
	#contact .topText {
		margin-bottom: 20px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#contact .bgWhite {
		padding: 40px 0;
	}
	#contact .telBox {
		margin-bottom: 50px;
	}
	#contact .telBox p {
		margin-bottom: 25px;
	}
	#contact .telBox .tel {
		margin-bottom: 20px;
		font-size: 2rem;
	}
	#contact .telBox .tel a {
		font-size: 3rem;
	}
	#contact .mailForm {
		padding: 40px 20px;
	}
	#contact .mailForm .headLine01 {
		margin-bottom: 35px;
	}
	#contact .mailForm table {
		margin-bottom: 30px;
	}
	#contact .mailForm th,
	#contact .mailForm td {
		padding-bottom: 20px;
		display: block;
	}
	#contact .mailForm th {
		padding-bottom: 10px;
		width: 100%;
	}
	#contact .mailForm tr:last-child th {
		padding-bottom: 10px;
	}
	#contact .mailForm .radioList {
		margin-bottom: 5px;
		display: block;
	}
	#contact .mailForm .radioList .wpcf7-radio {
		display: block;
	}
	#contact .mailForm .radioList li,
	#contact .mailForm .radioList .wpcf7-list-item {
		margin-bottom: 15px;
		display: block;
	}
	#contact .mailForm .radioList li:last-child,
	#contact .mailForm .radioList .wpcf7-list-item:last-child {
		margin-bottom: 0;
	}
	#contact .mailForm input[type="text"],
	#contact .mailForm input[type="tel"],
	#contact .mailForm input[type="email"],
	#contact .mailForm textarea {
		padding: 10px 15px;
		height: 45px;
		font-size: 1.4rem;
		border-radius: 5px;
	}
	#contact .mailForm input[type="email"] {
		margin-bottom: 0;
	}
	#contact .mailForm textarea {
		height: 200px;
	}
	#contact .mailForm .privacy {
		margin-bottom: 40px;
	}
	#contact .mailForm .submit {
		display: block;
	}
	#contact .mailForm .submit li {
		margin-top: 20px;
		width: auto;
	}
	#contact .mailForm .submit input {
		padding: 10px 30px;
		height: 60px;
		font-size: 1.6rem;
		letter-spacing: 0.1em;
		border-radius: 8px;
		background-position: right 15px center;
		background-size: 9px;
	}
}
/*------------------------------------------------------------
	news
------------------------------------------------------------*/
#news .mainBox {
	padding: 98px 0 200px;
	background: #EFF5F8;
}
#news .mainBox .content {
	padding: 100px 0;
	position: relative;
	background: #fff;
}
#news .mainBox .content .innerWrap {
	width: 1150px;
}
#news .mainBox .img01 {
	width: 150px;
	position: absolute;
	right: 0;
	top: -48px;
}
#news .newsList li {
	position: relative;
	border-bottom: 1px solid #DAE6ED;
}
#news .newsList li:first-child {
	border-top: 1px solid #DAE6ED;
}
#news .newsList li::after {
	width: 96px;
	height: 1px;
	position: absolute;
	right: 0;
	bottom: -1px;
	background: #003893;
	z-index: 1;
	content: '';
	transition: 0.5s;
}
#news .newsList li a {
	padding: 48px 7rem 49px 0;
	display: flex;
	font-size: 1.8rem;
	line-height: 1.54;
	letter-spacing: 0.03em;
	background: url(img/common/icon02.png) no-repeat right top 45% / 11px;
}
#news .newsList li .date {
	margin-top: 1px;
	width: 191px;
	font-size: 1.6rem;
	font-family: "Mulish", sans-serif;
	letter-spacing: 0.03em;
}
#news .newsList li .text {
	width: calc(100% - 191px);
	transition: 0.3s;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@media all and (min-width: 897px) {
	#news .newsList li:hover:after {
		width: 50%;
	}
	#news .newsList li a:hover .text {
		color: #003893;
	}
}
@media all and (max-width: 896px) {
	#news .mainBox {
		padding: 50px 0;
	}
	#news .mainBox .content {
		padding: 50px 0;
	}
	#news .mainBox .img01 {
		width: 75px;
		top: -30px;
	}
	#news .newsList li::after {
		width: 48px;
	}
	#news .newsList li a {
		padding: 25px 15px 25px 0;
		display: block;
		font-size: 1.4rem;
		background-size: 9px;
	}
	#news .newsList li .date {
		margin: 0 0 5px;
		width: auto;
		font-size: 1.4rem;
	}
	#news .newsList li .text {
		width: auto;
	}
}
/*------------------------------------------------------------
	news detail
------------------------------------------------------------*/
#news-detail .mainBox {
	padding: 98px 0 200px;
	background: #EFF5F8;
}
#news-detail .mainBox .content {
	padding: 100px 0;
	position: relative;
	background: #fff;
}
#news-detail .mainBox .content .innerWrap {
	width: 1150px;
}
#news-detail .date {
	margin-bottom: 17px;
	color: #003893;
	font-size: 1.8rem;
	letter-spacing: 0.03em;
}
#news-detail .title {
	margin-bottom: 100px;
	padding: 0 20px 17px 0;
	position: relative;
	font-size: 2.4rem;
	font-weight: 500;
	letter-spacing: 0.03em;
	line-height: 1.6;
	border-bottom: 1px solid #DAE6ED;
}
#news-detail .title::after {
	width: 192px;
	height: 1px;
	position: absolute;
	right: 0;
	bottom: -1px;
	background: #003893;
	z-index: 1;
	content: '';
}
#news-detail .detailBox {
	margin: 0 auto 198px;
	max-width: 768px;
}
#news-detail .detailBox a {
	transition: 0.3s;
}
#news-detail .detailBox a:hover {
	opacity: 0.7;
}
#news-detail .detailBox figure {
	margin-bottom: 48px;
	text-align: center;
}
#news-detail .detailBox p {
	margin-bottom: 29px;
	font-weight: 400;
	letter-spacing: 0.03em;
	line-height: 1.8125;
}
#news-detail .detailBox p:last-child {
	margin-bottom: 0;
}
#news-detail .pageNavi {
	display: flex;
	justify-content: center;
	position: relative;
}
#news-detail .pageNavi .prev,
#news-detail .pageNavi .next {
	width: 120px;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
#news-detail .pageNavi .back {
	width: 384px;
}
#news-detail .pageNavi .prev a,
#news-detail .pageNavi .next a,
#news-detail .pageNavi .back a {
	padding: 10px 20px;
	width: 100%;
	height: 40px;
	display: flex;
	align-items: center;
	position: relative;
	color: #fff;
	letter-spacing: 0.06em;
	background: url(img/common/icon03.png) no-repeat no-repeat left 18px center / 11px;
	border-radius: 50px;
	overflow: hidden;
}
#news-detail .pageNavi .back a {
	height: 64px;
	justify-content: center;
	background-position: left 29px center;
}
#news-detail .pageNavi .prev {
	left: -5px;
}
#news-detail .pageNavi .prev a {
	justify-content: flex-end;
}
#news-detail .pageNavi .next {
	right: -5px;
}
#news-detail .pageNavi .next a {
	background-image: url(img/common/icon01.png);
	background-position: right 18px center;
}
#news-detail .pageNavi .prev a::before,
#news-detail .pageNavi .next a::before,
#news-detail .pageNavi .back a::before {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	border-radius: inherit;
	background: #003893;
	content: '';
	z-index: -2;
}
#news-detail .pageNavi .prev a::after,
#news-detail .pageNavi .next a::after,
#news-detail .pageNavi .back a::after {
	width: 0;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	background: #001D4D;
	border-radius: inherit;
	content: '';
	z-index: -1;
	transition: 0.3s;
}
@media all and (min-width: 897px) {
	#news-detail .pageNavi .prev a:hover::after,
	#news-detail .pageNavi .next a:hover::after,
	#news-detail .pageNavi .back a:hover::after {
		width: 100%;
	}
}
@media all and (max-width: 896px) {
	#news-detail .mainBox {
		padding: 50px 0;
	}
	#news-detail .mainBox .content {
		padding: 40px 0 50px;
	}
	#news-detail .date {
		margin-bottom: 10px;
		font-size: 1.4rem;
	}
	#news-detail .title {
		margin-bottom: 50px;
		padding: 0 0 10px;
		font-size: 1.8rem;
	}
	#news-detail .title::after {
		width: 96px;
	}
	#news-detail .detailBox {
		margin-bottom: 50px;
		max-width: initial;
	}
	#news-detail .detailBox figure {
		margin-bottom: 30px;
	}
	#news-detail .detailBox p {
		margin-bottom: 15px;
	}
	#news-detail .pageNavi {
		padding-bottom: 60px;
		display: block;
	}
	#news-detail .pageNavi .prev,
	#news-detail .pageNavi .next {
		width: 120px;
		top: 55px;
		transform: none;
	}
	#news-detail .pageNavi .back {
		width: 100%;
	}
	#news-detail .pageNavi .prev a,
	#news-detail .pageNavi .next a,
	#news-detail .pageNavi .back a {
		background-position: left 15px center;
		background-size: 8px;
	}
	#news-detail .pageNavi .back a {
		height: 40px;
		background-position: left 15px center;
	}
	#news-detail .pageNavi .prev {
		width: 47%;
		left: 0;
	}
	#news-detail .pageNavi .next {
		width: 47%;
		right: 0;
	}
	#news-detail .pageNavi .next a {
		background-position: right 15px center;
	}
}
/*------------------------------------------------------------
	privacy
------------------------------------------------------------*/
#privacy .mainBox {
	padding: 200px 0;
	position: relative;
}
#privacy .mainBox .content {
	padding: 191px 0 200px;
	background: #EFF5F8;
}
#privacy .mainBox .whiteBox {
	padding: 70px 0 109px;
	background: #fff;
}
#privacy .topTxt {
	margin-bottom: 34px;
	font-size: 2rem;
	letter-spacing: 0.03em;
	line-height: 2.4;
}
#privacy .secBox {
	margin-bottom: 48px;
}
#privacy .secBox h3 {
	margin-bottom: 30px;
	padding-bottom: 9px;
	position: relative;
	color: #003893;
	font-weight: 500;
	font-size: 2rem;
	letter-spacing: 0.03em;
	border-bottom: 1px solid #C8D2DC;
}
#privacy .secBox h3::after {
	width: 100px;
	height: 4px;
	position: absolute;
	left: 0;
	bottom: -2px;
	background: #003893;
	z-index: 1;
	content: '';
}
#privacy .secBox p {
	margin-bottom: 23px;
	font-weight: 400;
	line-height: 1.78;
	letter-spacing: 0.03em;
}
#privacy .secBox p:last-child {
	margin-bottom: 0;
}
#privacy .secBox .txtList li {
	padding-left: 1em;
	text-indent: -1em;
	font-weight: 400;
	line-height: 1.78;
	letter-spacing: 0.03em;
}
#privacy .secBox01 {
	margin-bottom: 113px;
}
#privacy .btmBox p {
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 2.057;
	letter-spacing: 0.03em;
}
#privacy .btmBox p a:hover {
	opacity: 0.7;
}
@media all and (max-width: 896px) {
	#privacy .mainBox {
		padding: 126px 0 50px;
		position: relative;
	}
	#privacy .mainBox .content {
		margin: 0;
		padding: 40px 10px 50px;
	}
	#privacy .mainBox .whiteBox {
		padding: 40px 15px 50px;
	}
	#privacy .topTxt {
		margin-bottom: 20px;
		font-size: 1.6rem;
		line-height: 1.8;
	}
	#privacy .secBox {
		margin-bottom: 30px;
	}
	#privacy .secBox h3 {
		margin-bottom: 20px;
		padding-bottom: 5px;
		font-size: 1.6rem;
	}
	#privacy .secBox h3::after {
		height: 3px;
	}
	#privacy .secBox p {
		margin-bottom: 15px;
	}
	#privacy .secBox01 {
		margin-bottom: 50px;
	}
	#privacy .btmBox p {
		font-size: 1.2rem;
		line-height: 1.8;
	}
}
/*------------------------------------------------------------
	sitemap
------------------------------------------------------------*/
#sitemap .mainBox {
	padding: 98px 0 200px;
	background: #EFF5F8;
}
#sitemap .mainBox .content {
	padding: 100px 0;
	background: #fff;
}
#sitemap .mainBox .content .innerWrap {
	width: 1152px;
}
#sitemap .mainBox .linkList {
	border-top: 1px solid #DAE6ED;
}
#sitemap .mainBox .linkList > li {
	position: relative;
	border-bottom: 1px solid #DAE6ED;
}
#sitemap .mainBox .linkList > li::after {
	width: 96px;
	height: 1px;
	position: absolute;
	right: 0;
	bottom: -1px;
	background: #003893;
	z-index: 1;
	content: '';
	transition: 0.5s;
}
#sitemap .mainBox .linkList > li > a {
	padding: 29px 0;
	display: block;
	font-size: 1.8rem;
	letter-spacing: 0.03em;
	transition: 0.3s;
}
#sitemap .mainBox .linkList li a .txt {
	display: inline-block;
}
#sitemap .mainBox .linkList li a .txt::after {
	margin-left: 20px;
	width: 11px;
	height: 11px;
	display: inline-block;
	vertical-align: 2px;
	background: url(img/common/icon02.png) no-repeat center center / 100%;
	content: '';
}
#sitemap .mainBox .linkList li .subList {
	padding: 0 0 29px 30px;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 50px;
	font-size: 1.4rem;
	letter-spacing: 0.03em;
}
#sitemap .mainBox .linkList li .subList li a {
	display: inline-block;
	transition: 0.3s;
}
#sitemap .mainBox .linkList li .subList li a .txt::after {
	margin-left: 18px;
	vertical-align: 0;
}
#sitemap .mainBox .linkList > li.sm > a {
	padding: 29px 0 23px;
	font-size: 1.4rem;
}
#sitemap .mainBox .linkList > li.sm > a .txt::after {
	vertical-align: 0;
}
@media all and (min-width: 897px) {
	#sitemap .mainBox .linkList > li:hover:after {
		width: 50%;
	}
	#sitemap .mainBox .linkList > li a:hover {
		color: #003893;
	}
}
@media all and (max-width: 896px) {
	#sitemap .mainBox {
		padding: 50px 0;
	}
	#sitemap .mainBox .content {
		padding: 50px 0;
	}
	#sitemap .mainBox .linkList > li::after {
		width: 48px;
	}
	#sitemap .mainBox .linkList > li > a {
		padding: 20px 0;
		font-size: 1.6rem;
	}
	#sitemap .mainBox .linkList li a .txt::after {
		margin-left: 15px;
		width: 9px;
		height: 9px;
	}
	#sitemap .mainBox .linkList li .subList {
		padding: 0 0 15px 1em;
		gap: 10px 30px;
	}
	#sitemap .mainBox .linkList li .subList li a .txt::after {
		margin-left: 15px;
	}
	#sitemap .mainBox .linkList > li.sm > a {
		padding: 20px 0;
	}
}
/*------------------------------------------------------------
	active
------------------------------------------------------------*/
.loading {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 1111;
	background-color: #fff;
	opacity: 0;
	visibility: hidden;
	transition: all 0.8s ease-out;
	overflow: hidden;
}
@media all and (max-width: 896px) {
	.loading {
		width: 180%;
		height: 180%;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
	}
}
body.fadeout .loading {
	opacity: 1;
	visibility: visible;
	transition: all 0.8s ease-out;
}
.loading.hide {
	display: none;
}
.cover {
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 1112;
	background-color: #003893;
	opacity: 0;
	visibility: hidden;
	transition: all 0.8s ease-out;
}
body.fadeout .cover {
	opacity: 1;
	visibility: visible;
	transition: all 0.8s ease-out;
}
#index .bgBox::before {
	-webkit-clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
	clip-path: polygon(0 0, 100% 0, 100% 0, 0 0);
	transition: all 1s ease;
}
#index .bgBox.active::before {
	-webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
	clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
.fade {
	opacity: 0;
	transition: all 1s;
}
.fade.active {
	opacity: 1;
}
.fade.delay01 {
	transition-delay: 0.5s;
}
.fade.delay02 {
	transition-delay: 0.7s;
}
.fade.delay03 {
	transition-delay: 0.9s;
}
.fade.delay04 {
	transition-delay: 1.1s;
}
.fadeInUp {
	opacity: 0;
	transform: translateY(50px);
	transition: all 1s;
}
.fadeInUp.active {
	opacity: 1;
	transform: translateY(0);
}
.fadeIn {
	opacity: 0;
	transition: all 1s;
}
.fadeIn.active {
	opacity: 1;
}
.fadeInDelay {
	transition-delay: 0.5s;
}
#index .fvBox .innerBox .linkBox .link a .imgtext {
	animation: circRot 13s infinite linear;
}
@keyframes circRot {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}
.index {
	opacity: 0;
}
.index.active {
	opacity: 1;
}