@charset "UTF-8";

/* header
----------------------------------------*/
.header {
	opacity: 0;
	transition: opacity .5s;
	transition-timing-function: linear;
	transition-delay: .3s;
}

/* main
----------------------------------------*/
main {
	padding-top: 0;
}
header .header_logo,
header .gnav li:not(.gnav--blue):not(.gnav--gray) a {
	transition: filter .3s;
}
header.scroll .header_logo,
header.scroll .gnav li:not(.gnav--blue):not(.gnav--gray) a,
header.scroll .gnav li:not(.gnav--blue):not(.gnav--gray) button {
	filter: brightness(0);
}

/* mv
----------------------------------------*/
.mv {
	height: 100dvh;
}
.mv_bg {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	pointer-events: none;
	opacity: 0;
	transition: opacity .5s;
	transition-timing-function: linear;
}
.mv_bg::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .4;
}
.mv_bg img,
.mv_bg video {
	width: 100%;
	height: 100dvh;
	object-fit: cover;
}
.mv_box {
	color: #fff;
	padding: 11.8rem 0 0 5.6rem;
	opacity: 0;
	transition: opacity .5s;
	transition-timing-function: linear;
	transition-delay: .6s;
}
.mv_anim .mv_bg,
.mv_anim .header,
.mv_anim .mv_box {
	opacity: 1;
}
.mv_txt {
	margin-bottom: 3.8rem;
	filter: drop-shadow(0 0 2rem #000);
}
.mv_txt img {
	width: 56.9rem;
}
.mv_ttl {
	font-size: 5.3rem;
	line-height: 1.2642;
	font-weight: 400;
	letter-spacing: .05em;
	margin-bottom: 2.1rem;
	filter: drop-shadow(0 0 2rem #000);
}
.mv_ttl span:nth-of-type(1) {
	letter-spacing: -.03em;
}
.mv_ttl span:nth-of-type(2) {
	letter-spacing: -.21em;
	margin-left: -.1em;
}
.mv_ttl span:nth-of-type(3) {
	letter-spacing: -.1em;
}
.mv_ttl span:nth-of-type(4) {
	letter-spacing: -.05em;
}
.mv_ttl span:nth-of-type(5) {
	letter-spacing: -.09em;
}
.mv_box .en {
	font-size: 1.6rem;
	letter-spacing: .1em;
	line-height: 1.5;
	font-weight: 500;
	filter: drop-shadow(0 0 1rem #000);
}
@media only screen and (max-width: 768px) {
	.mv_bg::after {
		top: 0;
		bottom: 0;
	}
	.mv_box {
		padding: 8.3rem 0 0 2.4rem;
	}
	.mv_txt {
		margin-bottom: 1.1rem;
	}
	.mv_txt img {
		width: 32rem;
	}
	.mv_ttl {
		font-size: 3.6rem;
		line-height: 1.2778;
		margin-bottom: 1.6rem;
	}
	.mv_box .en {
		font-size: 1rem;
	}
}

/* intro
----------------------------------------*/
.intro {
	background: rgba(245, 245, 245, .9);
	mask-image: linear-gradient(#000, #000), url(../../img/index/logo.svg);
	mask-repeat: no-repeat, no-repeat;
	mask-position: 0 0, calc(50% - 41.8rem) 12.25rem;
	mask-size: 100% 100%, 20.2rem 12.15rem;
	mask-composite: exclude;
	padding: 12.2rem 0 25.8rem;
}
.intro_inner {
	max-width: 101.2rem;
	margin: 0 auto;
}
.intro_box {
	text-align: right;
}
.intro_box h2 {
	font-size: 3.6rem;
	font-weight: 400;
	letter-spacing: .1em;
	z-index: 10;
	margin-bottom: 6.9rem;
}
.intro_box h2 .en {
	display: block;
	font-size: 1rem;
	letter-spacing: .1em;
	margin: 2.7rem .3rem 0 0;
}
.intro_box > .en {
	text-align: left;
	font-size: 18rem;
	line-height: .9056;
	letter-spacing: .05em;
	color: #fff;
	position: absolute;
	left: -17.7rem;
	top: 26.5rem;
}
.intro_txt {
	font-size: 1.6rem;
	letter-spacing: .1em;
	line-height: 3.4375;
	margin-right: .2rem;
}
@media only screen and (max-width: 768px) {
	.intro {
		padding: 4rem 0 8rem;
		mask-position: 0 0, 2rem 4rem;
		mask-size: 100% 100%, 16.529rem 9.917rem;
	}
	.intro_box h2 {
		font-size: 3rem;
		margin-bottom: 3rem;
	}
	.intro_box h2 .en {
		margin: 1rem .3rem 0 0;
	}
	.intro_box {
		text-align: left;
		padding: 21rem 2.2rem 0 2.7rem;
		z-index: 2;
	}
	.intro_box > .en {
		font-size: 8rem;
		left: 0;
		top: 11rem;
	}
	.intro_txt {
		font-size: 1.4rem;
		line-height: 2.5;
	}
}

/*strength
----------------------------------------*/
.strength {
	background: url(../../img/index/strength_bg_01.jpg) no-repeat center center / cover;
	padding: 16rem 0 8rem;
}
.strength::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #00419A;
	opacity: .83;
	mix-blend-mode: multiply;
}
.strength_inner {
	max-width: 110rem;
	margin: 0 auto;
}
.strength_ttl > .en {
	position: absolute;
	top: -1.7rem;
	left: 0;
	right: 0;
	text-align: center;
	font-size: 11rem;
	z-index: 1;
	color: #477EC9;
	line-height: 1;
	letter-spacing: .05em;
}
.strength h2 {
	text-align: center;
	margin: 0 0 8.2rem;
	color: #fff;
	z-index: 2;
}
.strength h2 .serif {
	font-size: 3.6rem;
	letter-spacing: .1em;
	display: block;
	font-weight: 400;
}
.strength h2 .en {
	font-size: 1rem;
	letter-spacing: .1em;
	font-weight: 500;
	display: block;
	margin-top: .6rem;
}
.strength h3 {
	color: #fff;
	text-align: center;
	font-size: 2.6rem;
	font-weight: 500;
	letter-spacing: .1em;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2.3rem;
	margin-bottom: 4.9rem;
}
.strength h3::before,
.strength h3::after {
	content: '';
	display: block;
	width: 3.1rem;
	height: .1rem;
	margin-top: .3rem;
	background: #fff;
}
.strength_total {
	background: linear-gradient(45deg, #006bff 0%,#0099ff 100%);
	border-radius: 1.8rem;
	padding: 2.8rem 2rem 2.7rem;
}
.strength_total::after {
	content: '';
	display: block;
	width: 21.8828rem;
	height: 7.6025rem;
	background: url(../../img/index/strength_arrow_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	left: 0;
	right: 0;
	bottom: -6.2rem;
	margin: 0 auto;
}
.strength_total::before {
	content: '';
	display: block;
	background: #fff;
	position: absolute;
	top: .5rem;
	left: .5rem;
	right: .5rem;
	bottom: .5rem;
	border-radius: 1.5rem;
}
.strength_total dt,
.strength_box dl dt {
	text-align: center;
	font-size: 2rem;
	font-weight: 500;
	letter-spacing: .1em;
	color: #00419A;
	margin-bottom: 1.3rem;
}
.strength_total dd {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.4rem;
	letter-spacing: .1em;
	gap: 9.9rem;
}
.strength_total dd span + span::before {
	content: '';
	display: block;
	width: .1rem;
	position: absolute;
	top: 0;
	bottom: .1rem;
	left: -4.3rem;
	background: #000;
}
.strength_box {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 10rem;
	margin-top: 7.7rem;
}
.strength_box dl {
	background: linear-gradient(45deg, #006bff 0%,#0099ff 100%);
	border-radius: 1.8rem;
	padding: 2.8rem 2rem 2.7rem;
}
.strength_box dl::before {
	content: '';
	display: block;
	background: #fff;
	position: absolute;
	top: .5rem;
	left: .5rem;
	right: .5rem;
	bottom: .5rem;
	border-radius: 1.5rem;
}
.strength_box dl dd {
	text-align: center;
	font-size: 1.4rem;
}
.strength_box dl + dl::after {
	content: '';
	display: block;
	width: 3.5rem;
	height: 3.5rem;
	background: url(../../img/index/strength_cross_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 0;
	bottom: 0;
	left: -6.6rem;
	margin: auto 0;
}
.strength .index_btn {
	margin: 6rem auto 0;
}
@media only screen and (max-width: 768px) {
	.strength {
		padding: 5rem 0;
	}
	.strength_inner {
		margin: 0 2rem;
	}
	.strength_ttl > .en {
		top: -1rem;
		left: -1.8rem;
		right: -2rem;
		font-size: 7rem;
	}
	.strength h2 {
		margin-bottom: 5rem;
	}
	.strength h3 {
		font-size: 2rem;
		gap: 2rem;
		margin-bottom: 3rem;
	}
	.strength_total {
		padding: 2rem;
	}
	.strength_total dd {
		gap: 4rem;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		text-align: center;
	}
	.strength_total dd span + span::before {
		left: -2rem;
	}
	.strength_total::before,
	.strength_box dl::before {
		top: .3rem;
		left: .3rem;
		right: .3rem;
		bottom: .3rem;
	}
	.strength_box {
		gap: 4rem;
	}
	.strength_box dl {
		padding: 2rem 1rem;
	}
	.strength_box dl + dl::after {
		width: 2.4rem;
		height: 2.4rem;
		left: -3.2rem;
	}
	.strength_total dt,
	.strength_box dl dt {
		font-size: 1.7rem;
		line-height: 1.4;
		letter-spacing: .05em;
	}
	.strength_box dl dd {
		font-size: 1.3rem;
	}
	.strength .index_btn {
		margin: 4rem auto 0;
	}
}

/*business
----------------------------------------*/
.business {
	background: #F5F5F5;
	padding: 19.2rem 0 17.9rem;
}
.business_bg {
	width: calc(50% + 16.1rem);
	position: absolute;
	top: 0;
	left: 0;
	opacity: .35;
	z-index: 2;
}
.business_inner {
	max-width: 110rem;
	margin: 0 auto;
}
.business_inner > .en {
	font-size: 11rem;
	line-height: .8;
	color: #EAEAEA;
	letter-spacing: .05em;
	white-space: nowrap;
	margin-bottom: 6rem;
}
.business_box {
	display: flex;
	z-index: 3;
}
.business h2 {
	width: 14.3rem;
	display: flex;
	gap: 1.5rem;
	margin-left: 1rem;
	order: 0;
}
.business h2 .en {
	display: block;
	writing-mode: vertical-rl;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: .1em;
}
.business h2 .serif {
	display: block;
	writing-mode: vertical-rl;
	font-size: 3.6rem;
	font-weight: 400;
	letter-spacing: .28em;
	margin-top: -.6rem;
}
.business_txt {
	order: 1;
	flex: 1;
	margin-top: 5.1rem;
}
.business_txt p {
	font-size: 1.4rem;
	letter-spacing: .1em;
	line-height: 2.5;
}
.business_img {
	order: 2;
	display: flex;
	align-items: flex-start;
	gap: .9rem;
	width: 61.9rem;
	margin: -2.7rem -2.4rem 0 auto;
}
.business_img figure {
	width: 14.8rem;
}
.business_img figure::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(33,47,95,1) 100%);
}
.business_img figure:nth-child(1) {
	margin-top: 8.5rem;
}
.business_img figure:nth-child(2) {
	margin-top: 5.7rem;
}
.business_img figure:nth-child(3) {
	margin-top: 2.8rem;
}
.business_img figcaption {
	color: #fff;
	font-size: 1.4rem;
	font-feature-settings: "palt";
	font-weight: 500;
	position: absolute;
	left: 2rem;
	right: 0;
	bottom: 2.9rem;
	line-height: 1.4;
}
.business_img figcaption span {
	display: block;
	font-size: .8rem;
	font-weight: 400;
	letter-spacing: .1em;
	margin: .6rem 0 0;
}
.business_txt .index_btn {
	margin: 18.3rem 0 0;
}
@media only screen and (max-width: 768px) {
	.business {
		padding: 3rem 0 7.5rem;
	}
	.business_inner > .en {
		font-size: 7rem;
		line-height: 1.0429;
		white-space: wrap;
		margin: 0 0 -3.2rem 1.9rem;
	}
	.business_box {
		flex-wrap: wrap;
		padding: 0 2rem;
	}
	.business h2 {
		width: 7.9rem;
		gap: .2rem;
		margin-left: .2rem;
	}
	.business h2 .serif {
		margin-top: -.2rem;
	}
	.business_box figure {
		order: 1;
		width: 25.4rem;
		margin: 0;
	}
	.business_txt {
		order: 2;
		margin-top: 0;
	}
	.business_txt p {
		font-size: 1.3rem;
		line-height: 1.9231;
	}
	.business_txt .index_btn {
		margin: 3.6rem auto 0;
	}
	.business_img {
		gap: 1rem;
		width: auto;
		flex-wrap: wrap;
		margin: -26.5rem 0 0 9rem;
	}
	.business_box figure {
		width: calc((100% - 1rem) / 2);
	}
	.business_box figure img {
		width: 100%;
		height: 20rem;
		object-fit: cover;
	}
	.business_box figure:nth-child(n+3) {
		top: -3rem;
	}
	.business_img figcaption {
		font-size: 1.1rem;
		left: 1rem;
		bottom: 1.5rem;
	}
	.business_img figcaption span {
		font-size: .7rem;
	}
}

/*products
----------------------------------------*/
.products {
	background: #F5F5F5;
	padding-bottom: 3.4rem;
	z-index: 2;
}
.products > .en {
	text-align: center;
	font-size: 11rem;
	letter-spacing: .05em;
	padding-left: .05em;
	color: #fff;
	line-height: 1;
}
.products_inner {
	max-width: 110rem;
	margin: 0 auto;
}
.products h2 {
	text-align: center;
	margin: -9.5rem 0 3.6rem;
}
.products h2 .serif {
	display: block;
	font-size: 3.6rem;
	letter-spacing: .1em;
	padding-left: .1em;
	font-weight: 400;
	margin-bottom: .6rem;
}
.products h2 .en {
	display: block;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: .1em;
	padding-left: .1em;
}
.products_txt {
	text-align: center;
	font-size: 1.4rem;
	letter-spacing: .1em;
}
.products_img {
	display: flex;
	margin-top: 4.7rem;
}
.products_img::after {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #CEE3FF;
	opacity: .5;
}
.products_img figure {
	width: 155.5rem;
	flex-shrink: 0;
	animation-fill-mode: forwards;
	animation-duration: 40s;
	animation-name: products_img;
	animation-iteration-count: infinite;
	animation-timing-function: linear;
}
@keyframes products_img {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-100%);
	}
}
.products_btn {
	width: 88.9rem;
	height: 10rem;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background: #00419A;
	color: #fff;
	font-size: 2.6rem;
	font-weight: 500;
	letter-spacing: .05em;
	border-radius: .8rem;
	margin: 5.1rem auto 0;
}
.products_btn::before {
	content: '';
	display: block;
	width: 6rem;
	height: 6rem;
	border-radius: 50%;
	background: rgba(240, 240, 240, .7);
	backdrop-filter: blur(.3rem) brightness(127%);
	box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .21);
	position: absolute;
	right: 5.8rem;
	bottom: -1.4rem;
	z-index: 5;
}
.products_btn::after {
	content: '';
	display: block;
	width: 7.5rem;
	height: 7.8rem;
	background: url(../../img/index/product_icon_01.svg) no-repeat left top / 100% auto;
	position: absolute;
	right: 5.6rem;
	bottom: -2.9rem;
	z-index: 10;
}
.products_btn span + span::before {
	content: '';
	display: block;
	width: 11.2rem;
	height: 11.5rem;
	background: url(../../img/index/float_btn_img_01.png) no-repeat left top / 100% auto;
	position: absolute;
	right: 1.3rem;
	top: -2.8rem;
}
.products_btn span:first-child {
	display: block;
	width: fit-content;
}
.products_btn span:first-child::after {
	content: '';
	display: block;
	background: #fff url(../../img/index/icon_arrow_02.svg) no-repeat center center / .5rem auto;
	position: absolute;
	top: .6rem;
	bottom: 0;
	right: -3.4rem;
	width: 2.1rem;
	height: 2.1rem;
	border-radius: 50%;
	margin: auto 0;
}
.products_btn span + span {
	display: block;
	font-size: 1.1rem;
	letter-spacing: .05em;
	margin-top: .3rem;
	position: static;
}
@media only screen and (max-width: 768px) {
	.products {
		overflow: hidden;
	}
	.products > .en {
		font-size: 7rem;
		margin: 0 -1rem;
	}
	.products_inner {
		margin: 0 2rem;
	}
	.products h2 {
		margin: -4rem 0 1.9rem;
	}
	.products_txt {
		font-size: 1.3rem;
		line-height: 1.9231;
	}
	.products_img {
		margin-top: 3rem;
	}
	.products_img figure {
		width: 75rem;
	}
	.products_btn {
		width: auto;
		height: 7rem;
		align-items: flex-start;
		font-size: 1.8rem;
		margin: 5.1rem 2rem 0;
		padding-left: 2rem;
	}
	.products_btn::before {
		content: '';
		display: block;
		width: 4rem;
		height: 4rem;
		border-radius: 50%;
		background: rgba(230, 230, 230, .51);
		z-index: 1;
		position: absolute;
		bottom: -.2rem;
		right: 3.5rem;
		box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .21);
		transform: scale(.9);
	}
	.products_btn::after {
		content: '';
		display: block;
		width: 6.0243rem;
		height: 5.8rem;
		background: url(../../img/index/float_btn_img_02.svg) no-repeat left top / 100% auto;
		position: absolute;
		right: 2.3rem;
		bottom: -1.4rem;
		z-index: 2;
		transform: scale(.9);
	}
	.products_btn span + span::before {
		width: 7.4rem;
		height: 7.6rem;
		right: -3.5rem;
		top: -9rem;
	}
	.products_btn span:first-child::after {
		top: auto;
		bottom: .3rem;
		right: 8rem;
		margin: 0;
	}
	.products_btn span + span {
		font-size: 1rem;
		margin-top: .1rem;
		position: absolute;
		bottom: -2.5rem;
		left: 0;
		color: #333;
		pointer-events: none;
	}
}

/*news
----------------------------------------*/
.news {
	background: #F5F5F5;
	padding: 15.3rem 0 13rem;
}
.news_inner {
	max-width: 110rem;
	margin: 0 auto;
	display: flex;
}
.news h2 {
	width: 23.3rem;
	font-size: 24.3rem;
	display: flex;
	margin-left: 1rem;
	gap: 1.5rem;
}
.news h2 .en {
	display: block;
	writing-mode: vertical-rl;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: .1em;
}
.news h2 .serif {
	display: block;
	writing-mode: vertical-rl;
	font-size: 3.6rem;
	font-weight: 400;
	letter-spacing: .28em;
	margin-top: -.5rem;
}
.news_box {
	flex: 1;
}
.news_list {
	margin-bottom: 4.9rem;
}
.news_list li + li {
	margin-top: .2rem;
}
.news_list a {
	display: block;
	background: #fff;
	padding: 2.6rem 4.4rem 3.1rem 7.4rem;
}
.news_list a::before {
	content: '';
	display: block;
	width: .9rem;
	height: .9rem;
	border-radius: 50%;
	background: #00419A;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 3.7rem;
	margin: auto 0;
}
.news_time {
	font-size: 1rem;
	letter-spacing: .1em;
	color: #00419A;
	font-weight: 500;
}
.news_time::after {
	content: "";
	display: inline-block;
	width: .1rem;
	height: 1.1rem;
	background: #696969;
	margin: 0 .8rem 0 1.8rem;
	vertical-align: middle;
}
.news_category {
	font-size: 1rem;
	letter-spacing: .1em;
	font-weight: 500;
	color: #696969;
}
.news_ttl {
	font-size: 1.4rem;
	letter-spacing: .1em;
	margin-top: 1rem;
}
.news_box .index_btn {
	margin-left: auto;
}
@media only screen and (max-width: 768px) {
	.news {
		padding: 7.2rem 0 9.2rem;
	}
	.news_inner {
		display: block;
	}
	.news h2 {
		width: auto;
		display: flex;
		flex-direction: column;
		align-items: center;
		margin: 0 0 4.1rem;
		gap: .6rem;
	}
	.news h2 .en {
		writing-mode: unset;
	}
	.news h2 .serif {
		order: -1;
		writing-mode: unset;
		letter-spacing: .1em;
		padding-left: .1em;
	}
	.news_list {
		margin-bottom: 3.2rem;
	}
	.news_list a {
		padding: 2.5rem 4.4rem 2.9rem 7.4rem;
	}
	.news_list a::before {
		top: 5rem;
		bottom: auto;
		margin:0;
	}
	.news_ttl {
		font-size: 1.3rem;
		margin-top: .8rem;
		line-height: 1.9231;
	}
	.news_box .index_btn {
		margin-right: auto;
	}
}

/*company
----------------------------------------*/
.company {
	background: url(../../img/index/company_bg_01.jpg) no-repeat center center / cover;
	display: flex;
	justify-content: center;
	color: #fff;
	padding: 6.2rem 0 5.9rem;
}
.company::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #00419A;
	opacity: .53;
	mix-blend-mode: multiply;
}
.company_item {
	width: 55rem;
	color: #fff;
	padding: 1rem 0 5.4rem;
}
.company_item + .company_item::before {
	content: '';
	display: block;
	width: .1rem;
	position: absolute;
	left: 0;
	top: 0;
	bottom: 0;
	background: rgba(255, 255, 255, .5);
}
.company h2 {
	text-align: center;
	margin-bottom: 4rem;
}
.company h2 .serif {
	display: block;
	font-size: 3.6rem;
	letter-spacing: .1em;
	font-weight: 400;
}
.company h2 .en {
	display: block;
	font-size: 1rem;
	letter-spacing: .1em;
	font-weight: 500;
	margin-top: .6rem;
}
.company p {
	text-align: center;
	font-size: 1.4rem;
	letter-spacing: .1em;
	line-height: 1.7857;
}
.company_more {
	width: fit-content;
	display: block;
	margin: 0 auto;
	font-size: 1.4rem;
	letter-spacing: .05em;
	font-weight: 500;
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding-right: 3rem;
}
.company_more::after {
	content: '';
	display: block;
	width: 1.043rem;
	height: 1.043rem;
	background: url(../../img/common/gnav_arrow_icon.svg) no-repeat left top / 100% auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	margin: auto 0;
}
@media only screen and (max-width: 768px) {
	.company {
		background-image: url(../../img/index/company_bg_01-sp.jpg);
		display: block;
		padding: 4.8rem 2rem 5.6rem;
	}
	.company_item {
		width: auto;
		padding: 0;
	}
	.company_item + .company_item {
		border-top: .1rem solid rgba(255, 255, 255, .5);
		margin-top: 3.8rem;
		padding-top: 3rem;
	}
	.company_item + .company_item::before {
		display: none;
	}
	.company h2 {
		margin-bottom: 1.2rem;
	}
	.company h2 .serif,
	.company h2 .en {
		padding-left: .1em;
	}
	.company p {
		font-size: 1.3rem;
		line-height: 1.9231;
		padding-left: .1em;
		margin: 0 -.5rem;
	}
	.company_more {
		position: relative;
		left: auto;
		right: auto;
		bottom: auto;
		margin-top: 2rem;
		padding-left: 1rem;
	}
}

/*link
----------------------------------------*/
.link {
	background: #F5F5F5;
	padding: 9rem 0 8rem;
}
.link_inner {
	max-width: 110rem;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: .4rem;
}
.link a {
	display: flex;
	gap: 3rem;
	align-items: center;
	background: #fff;
	padding: 3.1rem 0 2.5rem 5.3rem;
}
.link a::after {
	content: '';
	display: block;
	width: 1.043rem;
	height: 1.043rem;
	background: url(../../img/index/link_arrow_icon.svg) no-repeat left top / 100% auto;
	position: absolute;
	right: 1.5rem;
	bottom: 1.5rem;
}
.link_item figure {
	width: 9.3rem;
}
.link_item_txt {
	flex: 1;
	margin-top: -.1rem;
}
.link_item h2 .serif {
	font-size: 1.6rem;
	letter-spacing: .1em;
	font-weight: 400;
	display: block;
}
.link_item h2 span:not(.serif) {
	font-size: 1rem;
	line-height: 1.3;
	letter-spacing: .1em;
	font-weight: 500;
	display: block;
	color: #00419A;
}
.link_item p {
	font-size: 1.4rem;
	letter-spacing: .1em;
	line-height: 1.8571;
	margin-top: 1.6rem;
}
@media only screen and (max-width: 768px) {
	.link {
		padding: 6rem 2rem 2.1rem;
	}
	.link_inner {
		grid-template-columns: repeat(1, 1fr);
		gap: .2rem;
	}
	.link a {
		display: block;
		padding: 2.6rem 3rem 1.9rem;
	}
	.link a::after {
		bottom: 1.6rem;
	}
	.link_item figure {
		width: 4.8rem;
		position: absolute;
		left: 2rem;
		top: 2rem;
	}
	.link_item h2 {
		padding-left: 5.7rem;
	}
	.link_item p {
		font-size: 1.3rem;
		line-height: 1.8462;
	}
}

/*recruit
----------------------------------------*/
.recruit {
	background: #F5F5F5;
	padding: 0 0 12.3rem;
}
.recruit a {
	max-width: 110rem;
	height: 20rem;
	margin: 0 auto;
	display: flex;
	align-items: center;
	padding: .1rem 0 0 7.7rem;
	background: #fff url(../../img/index/recruit_bg_01.jpg) no-repeat 7.5rem center / 100rem auto;
}
.recruit h2 .serif {
	font-size: 2.6rem;
	font-weight: 400;
	letter-spacing: .1em;
	display: block;
	padding-right: 5.7rem;
}
.recruit h2 .serif::before {
	content: '';
	display: block;
	width: 2rem;
	height: 2rem;
	background: #E8E8E8 url(../../img/index/link_arrow_icon.svg) no-repeat center center / 1.043rem auto;
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto 0;
}
.recruit h2 .en {
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: .1em;
	display: block;
	margin-top: 1rem;
}
@media only screen and (max-width: 768px) {
	.recruit {
		padding: 0 2rem 8.2rem;
	}
	.recruit a {
		height: 16rem;
		padding: .1rem 0 .7rem 2.2rem;
		background: #fff url(../../img/index/recruit_bg_01-sp.jpg) no-repeat left center / 100% auto;
	}
	.recruit h2 .serif {
		font-size: 1.6rem;
		padding-right: 0;
	}
	.recruit h2 .serif::before {
		display: none;
	}
	.recruit h2 .en {
		width: fit-content;
		margin-top: 1.3rem;
		padding-right: 2.7rem;
	}
	.recruit h2 .en::before {
		content: '';
		display: block;
		width: 1.4rem;
		height: 1.7rem;
		background: #E8E8E8 url(../../img/index/link_arrow_icon.svg) no-repeat center center / .864rem auto;
		position: absolute;
		right: 0;
		top: .2rem;
		bottom: 0;
		margin: auto 0;
	}
}

/*index_btn
----------------------------------------*/
.index_btn {
	display: flex;
	align-items: center;
	width: 25.3rem;
	height: 5.6rem;
	border-radius: .8rem;
	background: #00419A;
	color: #fff;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: .05em;
	padding: 0 2.6rem;
}
.index_btn::after {
	content: '';
	display: block;
	width: 1.043rem;
	height: 1.043rem;
	background: url(../../img/common/gnav_arrow_icon.svg) no-repeat left top / 100% auto;
	position: absolute;
	right: 3rem;
	top: .2rem;
	bottom: 0;
	margin: auto 0;
}
.index_btn.border {
	border: .1rem solid #00419A;
	background: none;
	color: #000;
}
.index_btn.border::after {
	filter: brightness(0);
	right: 3rem;
}
.index_btn.white {
	border: .1rem solid #fff;
	background: none;
	color: #fff;
}
.index_btn.white::after {
	right: 3rem;
}

/*float_btn
----------------------------------------*/
.float_btn {
	position: fixed;
	right: 3rem;
	bottom: 3rem;
	z-index: 2000;
	opacity: 0;
	transition: opacity .5s;
	transition-timing-function: linear;
	transition-delay: .9s;
}
.mv_anim .float_btn {
	opacity: 1;
}
.float_btn a {
	padding-right: 1.8rem;
	display: block;
}
.float_btn a::before {
	content: '';
	display: block;
	width: 6.0243rem;
	height: 5.8rem;
	background: url(../../img/index/float_btn_img_02.svg) no-repeat left top / 100% auto;
	position: absolute;
	right: 5.3rem;
	bottom: -.9rem;
	z-index: 2;
	transition: filter .2s;
}
.float_btn a::after {
	content: '';
	display: block;
	width: 4rem;
	height: 4rem;
	border-radius: 50%;
	background: rgba(230, 230, 230, .51);
	z-index: 1;
	position: absolute;
	bottom: .3rem;
	right: 6.5rem;
	backdrop-filter: blur(.2rem) brightness(127%);
	box-shadow: .3rem .3rem .6rem rgba(0, 0, 0, .21);
}
.float_btn a span:not(.en) {
	display: flex;
	align-items: center;
	width: 25.3rem;
	height: 5.6rem;
	background: #fff;
	border-radius: .8rem;
	font-size: 1.3rem;
	font-weight: 500;
	color: #00419A;
	padding: 0 2rem;
	letter-spacing: .05em;
	transition: background .3s, color .3s;
}
.float_btn a span:not(.en)::after {
	content: '';
	display: block;
	background: #00419A url(../../img/index/icon_arrow_01.svg) no-repeat center center / .3555rem auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 10.4rem;
	width: 1.5rem;
	height: 1.5rem;
	border-radius: 50%;
	margin: auto 0;
}
.float_btn a span.en {
	font-size: 4.3rem;
	letter-spacing: .03em;
	font-weight: 500;
	color: #fff;
	line-height: 1;
	margin: 0 0 -.7rem .8rem;
	display: block;
	transition: color .3s;
}
.float_btn a span:not(.en)::before {
	content: '';
	display: block;
	width: 8.2rem;
	height: 8.5rem;
	background: url(../../img/index/float_btn_img_01.png) no-repeat left top / 100% auto;
	position: absolute;
	right: 1.3rem;
	top: -3.7rem;
}
.float_btn.color a span.en {
	color: #00419A;
}
.float_btn.color a span:not(.en) {
	background: #00419A;
	color: #fff;
}
.float_btn.color a::before {
	filter: brightness(0) invert(1);
}
.float_btn.color a span:not(.en)::after {
	background: #fff url(../../img/index/icon_arrow_02.svg) no-repeat center center / .3555rem auto;
}
@media only screen and (max-width: 768px) {
	.footer .copyright {
		padding-bottom: 12rem;
	}
	.float_btn {
		right: 0;
		bottom: 1.6rem;
		transform-origin: right bottom;
		transform: scale(.8);
	}
	.float_btn a {
		padding-right: 1.6rem;
	}
	.float_btn a::before {
		right: 4.717rem;
		transform: scale(.9);
	}
	.float_btn a::after {
		right: 5.785rem;
		transform: scale(.9);
	}
	.float_btn a span:not(.en) {
		width: 22.7rem;
		height: 5rem;
		font-size: 1.2rem;
		padding: 0 1.4rem;
	}
	.float_btn a span:not(.en)::after {
		transform: scale(.9);
		right: 9.3rem;
	}
	.float_btn a span.en {
		font-size: 3.8rem;
		margin: 0 0 -.5rem .7rem;
	}
	.float_btn a span:not(.en)::before {
		width: 7.4rem;
		height: 7.6rem;
		right: 1.2rem;
		top: -3.4rem;
	}
	.float_btn_close {
		appearance: none;
		width: 2.7rem;
		height: 2.7rem;
		border-radius: 50%;
		background: #fff;
		position: absolute;
		top: -1rem;
		right: 1rem;
		border: 0;
		z-index: 10;
		box-shadow: 0 0 .2rem rgba(0, 0, 0, .5);
	}
	.float_btn_close::before,
	.float_btn_close::after {
		content: '';
		display: block;
		width: .1rem;
		height: 1.8rem;
		background: #000;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		margin: auto;
		transform: rotate(45deg);
	}
	.float_btn_close::after {
		transform: rotate(-45deg);
	}
}
