@charset "UTF-8";
/*------------------------------------
オープニング
------------------------------------*/
.shutter {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background-color: #0062b1;
	z-index: 99999;
	-webkit-animation: byeShutter 2.6s forwards;
			animation: byeShutter 2.6s forwards;
}
.shutter:before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	background-color: #fff;
	width: 0;
	height: 1px;
	margin: auto;
	-webkit-animation: shutterOpen 2.6s forwards;
			animation: shutterOpen 2.6s forwards;
}
@-webkit-keyframes byeShutter {
	70% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		display: none;
		z-index: -1;
	}
}
@keyframes byeShutter {
	70% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		display: none;
		z-index: -1;
	}
}
@-webkit-keyframes shutterOpen {
	0% {
		width: 0;
		height: 1px;
	}
	50% {
		width: 100%;
		height: 1px;
	}
	90% {
		width: 100%;
		height: 100%;
	}
	100% {
		width: 100%;
		height: 100%;
	}
}
@keyframes shutterOpen {
	0% {
		width: 0;
		height: 1px;
	}
	50% {
		width: 100%;
		height: 1px;
	}
	90% {
		width: 100%;
		height: 100%;
	}
	100% {
		width: 100%;
		height: 100%;
	}
}
@-webkit-keyframes contentScale {
	70% {
		transform: perspective(800px) scale(0.9) rotateX(15deg);
	}
	100% {
		transform: perspective(800px) scale(1) rotateX(0);
	}
}
@keyframes contentScale {
	70% {
		transform: perspective(800px) scale(0.9) rotateX(15deg);
	}
	100% {
		transform: perspective(800px) scale(1) rotateX(0);
	}
}
@media screen and (max-width: 768px) {}


/*------------------------------------
.mv
------------------------------------*/
.mv {
	position: relative;
	background-color: #0062b1;
	height: 836px;
}
.mv .top-mainvisual {
	position: relative;
	background-image: url("../images/top/mv.webp");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 836px;
	margin-left: 77px;
}
.mv .top-mainvisual:before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	background-image: url("../images/top/index-img-main-bg-l.png");
	background-size: cover;
	width: 100px;
	height: 100px;
}
.mv .top-mainvisual img {
	position: absolute;
	top: 156px;
	left: 125px;
}
.mv .top-main-bg {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 200px;
	z-index: 2;
}
.mv .top-main-bg:after {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	background-image: url("../images/top/index-img-main-bg-r.webp");
	background-size: cover;
	width: 200px;
	height: 200px;
}
.mv .top-main-bg span {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	background-color: #0062b1;
	width: calc(100% - 200px);
	height: 100px;
}
@media screen and (max-width: 768px) {
	.mv {
		height: 640px;
	}
	.mv .top-mainvisual {
		height: 640px;
		margin-left: 5vw;
	}
	.mv .top-mainvisual:before {
		width: 20px;
		height: 20px;
	}
	.mv .top-mainvisual img {
		top: 64px;
		left: 40px;
		width: 35.5%;
	}
	.mv .top-main-bg {
		height: 40px;
	}
	.mv .top-main-bg:after {
		width: 40px;
		height: 40px;
	}
	.mv .top-main-bg span {
		width: calc(100% - 40px);
		height: 20px;
	}
}

/*.news*/
.mv .news {
	display: flex;
	align-items: center;
	position: relative;
	bottom: 220px;
	background-color: #fff;
	border-radius: 30px;
	max-width: 1260px;
	width: calc(100% - 30vw);
	height: 60px;
	filter: drop-shadow(1px 2px 7px rgba(0, 0, 0, 0.1));
	margin: 0 auto;
	z-index: 3;
}
.mv .news a {
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
	height: 60px;
	padding: 0 40px;
}
.mv .news a time {
	border-right: 1px solid #ccd4e0;
	letter-spacing: .08em;
	line-height: 1;
	padding-right: 16px;
}
.mv .news a p {
	padding-left: 16px;
}
.mv .news a .arrow {
	background-image: url("../images/common/btn-arrow.svg");
	background-size: cover;
	width: 7px;
	height: 12px;
	margin-left: auto;
}
@media screen and (max-width: 768px) {
	.mv .news {
		bottom: 120px;
		border-radius: 25px;
		width: calc(100% - 20vw);
		height: 50px;
	}
	.mv .news a {
		height: 50px;
		padding: 0 24px;
	}
	.mv .news a time {
		letter-spacing: 0;
		padding-right: 8px;
	}
	.mv .news a p {
		white-space: normal;
		overflow: hidden;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 1; /* 任意の行数を指定 */
		max-width: 160px; /* 例：表示文字数を抑えるために幅を制限 */
		padding-left: 8px;
	}
}


/*------------------------------------
.top
------------------------------------*/
.top {
	background-color: #0062b1;
	padding-bottom: 50px;
}
.top .container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 40px;
	position: relative;
	max-width: 1260px;
	width: calc(100% - 154px);
	margin: -50px auto 0;
	z-index: 4;
}
.top h1 {
	font-size: 18px;
	line-height: 1.78;
	color: #fff;
}
.top .banner {
	display: flex;
	gap: 40px;
	width: calc(680 / 1260 * 100%);
}
.top .banner img {
	width: 100%;
}
@media screen and (max-width: 768px) {
	.top {
		padding-bottom: 100px;
	}
	.top .container {
		flex-direction: column;
		gap: 20px;
		width: calc(100% - 10vw);
		margin: 0 auto;
	}
	.top h1 {
		font-size: 16px;
		text-align: center;
	}
	.top .banner {
		gap: 20px;
		width: 100%;
	}
}


/*------------------------------------
#business
------------------------------------*/
#business {
	padding-top: 120px;
}
#business .container {
	display: flex;
	flex-direction: row-reverse;
	gap: 135px;
	max-width: 1260px;
	width: calc(100% - 154px);
	margin: 0 auto;
}
#business .img {
	max-width: 617px;
	margin-right: -92px;
}
#business .txt {
	max-width: 600px;
	width: 100%;
}
#business .txt .g-h {
	align-items: baseline;
	margin-bottom: 16px;
}
#business .txt .desc {
	font-size: 32px;
	line-height: 1.40625;
	margin-bottom: 32px;
}
#business .txt .link {
	margin-top: 32px;
}
#business .txt .link a {
	margin: 0;
}
@media screen and (max-width: 1444px) {
	#business .container {
		align-items: center;
		gap: 40px;
	}
	#business .img {
		margin-right: 0;
	}
}
@media screen and (max-width: 768px) {
	#business {
		margin-top: -50px;
		padding: 0 0 80px;
	}
	#business .container {
		flex-direction: column;
		width: calc(100% - 10vw);
	}
	#business .txt {
		margin-top: -70px;
	}
	#business .txt .desc {
		font-size: 20px;
		margin-bottom: 16px;
	}
	#business .txt .link a {
		margin: 0 auto;
	}
}


/*------------------------------------
#cases
------------------------------------*/
#cases {
	background-color: #f2f9ff;
	padding: 120px 0;
	margin-top: -50px;
}
#cases .desc {
	font-size: 32px;
	line-height: 1.40625;
	text-align: center;
	margin-bottom: 64px;
	padding: 0 77px;
}
#cases .cases-slider li img {
	width: 100%;
	filter: drop-shadow(1px 2px 7px rgba(0, 0, 0, 0.1));
}
#cases .container {
	text-align: center;
	margin-top: 40px;
	padding: 0 77px;
}
#cases .link {
	margin-top: 32px;
}
@media screen and (min-width: 769px) {
	#cases .cases-slider {
		display: flex;
		gap: 30px;
		max-width: 1260px;
		width: calc(100% - 154px);
		margin: 0 auto;
	}
	#cases .cases-slider li {
		width: calc((100% - 60px)/3);
	}
}
@media screen and (max-width: 768px) {
	#cases {
		padding: 80px 0;
		margin-top: 0;
	}
	#cases .desc {
		font-size: 20px;
		margin-bottom: 32px;
		padding: 0 10vw;
	}
	#cases .cases-slider li {
		margin: 0 10px;
	}
	#cases .container {
		padding: 0 10vw;
	}
}


/*------------------------------------
#feature
------------------------------------*/
#feature {
	counter-reset: listnum;
	padding: 120px 0;
}
#feature .container {
	position: relative;
	padding: 100px 0;
}
#feature .container::before {
	content: "";
	position: absolute;
	top: 0;
	background-color: #f2f9ff;
	height: 100%;
	z-index: -1;
	left: max(60px, calc(50% - 570px + 60px)); /* max-width を1140pxに合わせて調整 */
	right: 0;
}
#feature .block {
	counter-increment: listnum;
	display: flex;
	align-items: center;
	gap: 60px;
	max-width: 1140px;
	width: calc(100% - 154px);
	margin: 0 auto;
}
#feature .block:nth-child(even) {
	flex-direction: row-reverse;
}
#feature .block:not(:last-child) {
	margin-bottom: 70px;
}
#feature .block .img {
	width: calc(550 / 1140 * 100%);
}
#feature .block .img img {
	filter: drop-shadow(1px 2px 7px rgba(0, 0, 0, 0.1));
}
#feature .block .txt {
	width: calc(390 / 1140 * 100%);
}
#feature .block .txt h3 {
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-size: 32px;
	margin-bottom: 16px;
}
#feature .block .txt h3:before {
	content: counter(listnum, decimal-leading-zero);
	font-size: 70px;
	font-style: italic;
	color: #0062b1;
}
@media screen and (max-width: 768px) {
	#feature {
		padding: 80px 0;
	}
	#feature .container {
		padding: 64px 0;
	}
	#feature .container::before {
		left: 10vw;
	}
	#feature .block,
	#feature .block:nth-child(even) {
		flex-direction: column;
	}
	#feature .block {
		gap: 0;
		width: calc(100% - 10vw);
	}
	#feature .block .img,
	#feature .block .txt {
		width: 100%;
	}
	#feature .block .txt {
		margin-top: -35px;
		padding-left: 10vw;
		z-index: 1;
	}
	#feature .block .txt h3 {
		font-size: 20px;
	}
	#feature .block .txt h3:before {
		font-size: 50px;
	}
}


/*------------------------------------
#products
------------------------------------*/
#products {
	background-color: #0062b1;
	padding: 120px 0;
}
#products .g-h .en,
#products .g-h .jp {
	color: #fff;
}
#products .container {
	max-width: 1260px;
	width: calc(100% - 154px);
	margin: 0 auto;
}
#products .container > p {
	text-align: center;
	color: #fff;
	margin-bottom: 64px;
}
#products .list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px 30px;
}
#products .list li {
	width: calc((100% - 60px)/3);
}
#products .list li a {
	display: block;
	background-color: #fff;
	border-radius: 16px;
	height: 100%;
	padding: 60px 40px;
}
#products .list li img {
	display: block;
	width: 200px;
	height: 70px;
	margin: 0 auto 20px;
}
#products .list li .txt span {
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #ebf5ff;
	border-radius: 19px;
	max-width: 246px;
	height: 38px;
	text-align: center;
	color: #0062b1;
	margin: 0 auto;
}
@media screen and (max-width: 768px) {
	#products {
		padding: 80px 0;
	}
	#products .container {
		width: calc(100% - 10vw);
	}
	#products .container > p {
		text-align: left;
		margin-bottom: 32px;
	}
	#products .list {
		flex-direction: column;
		gap: 20px;
	}
	#products .list li {
		width: 100%;
	}
	#products .list li a {
		display: flex;
		gap: 20px;
		padding: 30px 20px;
	}
	#products .list li img {
		width: 100px;
		height: 50px;
		margin: 0;
	}
	#products .list li .txt {
		width: calc(100% - 120px);
	}
	#products .list li .txt p {
		font-size: 12px;
		line-height: 1.5;
		margin-top: 10px;
	}
}


/*------------------------------------
#faq
------------------------------------*/
#faq {
	padding: 100px 0 200px;
}
#faq .container {
	max-width: 1260px;
	width: calc(100% - 154px);
	margin: 0 auto;
}
#faq #accordion {
	margin-bottom: 64px;
}
@media screen and (max-width: 768px) {
	#faq {
		padding: 50px 0;
	}
	#faq .container {
		width: calc(100% - 10vw);
	}
	#faq #accordion {
		margin-bottom: 32px;
	}
}
