@charset "utf-8";
/* ============================================================ */
/*  index */
/* ============================================================ */

body.index .l-contents {
	padding-bottom: 0;
} 

/* c-index-visual
------------------------------------------------------------ */
.c-index-visual {
	position: relative;
	height: calc(100svh - 100px);
	padding: 10px;
	background-color: var(--white);
	margin-top: 100px;
	position: relative;
	margin-bottom: 100px;
}

.c-index-visual__video {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border: solid 6px var(--white);
}

.c-index-visual__logo {
	position: absolute;
	left: 49.01%;
	left: 50%;
	top: 50%;
	translate: -50% -50%;
	width: 64px;
	height: 252px;
	opacity: 0;
	animation: logo 1s calc(var(--index-mv-animation-speed) * 4.5) ease 1 forwards;
}

.c-index-visual__logo .__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.c-index-visual__line {
	position: absolute;
	left: 26px;
	top: 26px;
	z-index: 100;
	width: calc(50% - 23px);
	height: calc(100% - 52px);
}

.c-index-visual__line._right_ {
	right: 26px;
	left: auto;
	rotate: 180deg;
}

.c-index-visual__line .__line {
	background-color: var(--white);
	display: block;
	position: absolute;
}

.c-index-visual__line ._top_,
.c-index-visual__line ._bottom_ {
	width: 100%;
	height: 6px;
}

.c-index-visual__line ._left_,
.c-index-visual__line ._right_ {
	width: 6px;
	height: 100%;
}

.c-index-visual__line ._top_ {
	top: 0;
	left: 0;
	width: calc(100% - 16px);
	animation: left var(--index-mv-animation-speed) 0s linear 1 forwards;
	clip-path: inset(0 0 0 100%);
}

.c-index-visual__line ._left_ {
	top: 0;
	left: 0;
	animation: down var(--index-mv-animation-speed) calc(var(--index-mv-animation-speed) *1) linear 1 forwards;
	clip-path: inset(0 0 100% 0);
}

.c-index-visual__line ._bottom_ {
	bottom: 0;
	left: 0;
	animation: right var(--index-mv-animation-speed) calc(var(--index-mv-animation-speed) *2) linear 1 forwards;
	clip-path: inset(0 100% 0 0);
}

.c-index-visual__line ._right_ {
	bottom: 0;
	right: 0;
	height: 33.37%;
	height: calc(50vh - 210px);
	animation: up var(--index-mv-animation-speed) calc(var(--index-mv-animation-speed) *3) linear 1 forwards;
	clip-path: inset(100% 0 0 0);
}

@keyframes left {
	0% {
		clip-path: inset(0 0 0 100%);
	}
	100% {
		clip-path: inset(0 0 0 0);
	}
}

@keyframes down {
	0% {
		clip-path: inset(0 0 100% 0);
	}
	100% {
		clip-path: inset(0 0 0 0);
	}
}

@keyframes right {
	0% {
		clip-path: inset(0 100% 0 0);
	}
	100% {
		clip-path: inset(0 0 0 0);
	}
}

@keyframes up {
	0% {
		clip-path: inset(100% 0 0 0);
	}
	100% {
		clip-path: inset(0 0 0 0);
	}
}

@keyframes logo {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}

.c-index-visual__scroll {
	position: absolute;
	bottom: 26px;
	right: 26px;
	width: 48px;
	height: 48px;
	background-color: var(--white);
	display: grid;
	place-content: center;
}

/* c-index-news
------------------------------------------------------------ */
.c-index-news {
	padding-left: calc(var(--pl-percent) * 1%);
	display: flex;
	align-items: flex-start;
	column-gap: 5%;
	position: relative;
	margin-bottom: 80px;
}
.c-index-news::before {
	top: 189px;
	left: 8.33%;
}

.c-index-news__inner {
	flex: 1;
	width: 60%;
}

.c-index-news__list {
	margin-bottom: 80px;
}

.c-index-news .__ttl {
	margin-bottom: 42px;
}

.c-index-news .__btn {
	margin-left: auto;
	
}

.c-index-news__ttl {
	overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.c-index-news__img {
	width: 29.17%;
	width: 35%;
}

.c-index-news__img .__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* c-index-message
------------------------------------------------------------ */
.c-index-message {
	margin-bottom: 80px;
}

.c-index-message::before {
	top: -296px;
	right: 0;
}

.c-index-message::after {
	content: "";
	position: absolute;
	width: 800px;
  height: 1200px;
  background: url(../../img/common/bg_triangle_blue.svg) no-repeat center / contain;
	top: 382px;
	left: 0;
	z-index: -100;
}

.c-index-message__inner {
	width: 83.33%;
	display: flex;
	justify-content: space-between;
}

.c-index-message__wrap {
	padding-top: 75px;
	margin-bottom: 160px;
	width: 40%;
}
@media screen and (max-width: 1240px) {
	.c-index-message__wrap {
		width:50%;
	}
}

.c-index-message__txt {
	font-size: 2.9rem;
	margin-bottom: 65px;
}
@media screen and (max-width: 1400px) {
	.c-index-message__txt {
		font-size: 2.8rem;
	}
}
@media screen and (max-width: 1240px) {
	.c-index-message__txt {
		font-size: 2.1rem;
	}
}

.c-index-message__img._img01_ {
	width: 37.5%;
	aspect-ratio: 600/ 800;
}

.c-index-message__img._img03_ {
	width: 50%;
	margin: 0 auto;
}

/* c-index-business
------------------------------------------------------------ */
.c-index-business {
	margin-bottom: 160px;
}
.c-index-business::before {
	right: 8.85%;
	top: -208px;
	rotate: 180deg;
}

.c-index-business__inner {
	display: flex;
	justify-content: space-between;
	column-gap: 6.25%;
}

@media screen and (max-width:1024px) {
	.c-index-business__txt{
		font-size:1.35rem;
	}
}

.c-index-business__video {
	width: 43.75%;
	aspect-ratio: 560/ 373;
	object-fit: cover;
}

/* c-index-company
------------------------------------------------------------ */
.c-index-company {
	background-color: var(--blue2);
}

.c-index-company__bg {
	position: relative;
	height: 640px;
	width: 100%;
	padding-top: 4.17%;
	margin-bottom: 50px;
}

.c-index-company__bg-txt {
	font-size: 3.2rem;
	font-weight: 700;
	position: relative;
	z-index: 4;
	display: inline-flex;
	flex-direction: column;
	row-gap: 24px;
	float: right;
	margin-right: calc(var(--pl-percent) * 1%);
}

.c-index-company__bg-txt .__txt {
	background-color: var(--white);
	display: inline-block;
	width: max-content;
	padding: 0 4px;
}

.c-index-company__bg-txt .__txt .__blue {
	color: var(--blue);
}

.c-index-company__img {
	position: absolute;
	inset: 0;
	width: 100%;
	z-index: 2;
}

.c-index-company__img::before {
	content: "";
	position: absolute;
	inset: 0;
	height: 100%;
	width: 100%;
	background: url(../../img/index/bg_company_dot.png) repeat left top;
	z-index: 3;
}

.c-index-company__img .__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.c-index-company__inner {
	display: flex;
	align-items: center;
}

.c-index-company__txt {
	margin-left: 80px;
}

.c-index-company__inner .__btn {
	margin-left: auto;
}

/* c-index other
------------------------------------------------------------ */
/* body.index .l-footer {
	margin-top: -30px;
} */