@charset "utf-8";

/* トップページ
============================ */

/* 動画背景
------------------------------------------------- */
#contentsArea {
	position: relative;
	overflow: hidden;
}
#contentsArea::after {
	position: absolute;
	content: "";
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(14, 50, 76, 0.8);
	z-index: 0;
}
video#bgvid {
		display: block;
		position: fixed;
		right: 0;
		top: 0;/* 90px; ★ヘッダ高さ（PC） */
		min-width: 100%;
		min-height: 100%;
		width: auto;
		height: auto;
		z-index: -100;
	}
	@media screen and (min-width:1025px) {
	video#bgvid {
		display: block;
		position: fixed;
		right: 0;
		top: 0;/* 90px; ★ヘッダ高さ（PC） */
		min-width: 100%;
		min-height: 100%;
		width: auto;
		height: auto;
		z-index: -100;
	}
}

/* キャッチコピー
------------------------------------------------- */
.copy {
	position: relative;
	z-index: 1;
	width: 100%;
	height: calc(85vh);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.copy h1 {
	width: 94%;
	color: #fff;
	text-align: center;
	margin: 0 auto;
}
.copy h1 em {
	display: block;
	width: 94%;
	height: 0;
	padding-top: 13.75770020533881%;
	text-indent: -9999px;
	background: url(../images/copy.svg) 0 0 no-repeat;
	background-size: 100%;
	margin: 0 auto 10px;
}
.copy h1 span {
	display: block;
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
	font-size: 2rem;
	letter-spacing: 0.08em;
	}
	@media (orientation: landscape) {
	.copy {
		height: calc(150vh);
	}
	}
	@media screen and (min-width:1025px) {
	.copy {
		height: calc(100vh);
		margin: 45px 0 -90px;
	}
	.copy h1 em {
		width: 1020px;
		height: 114px;
		margin: 0 auto 6px;
		padding: 0;
	}
	.copy h1 span {
		font-size: 4.8rem;
		letter-spacing: 0.08em;
	}
}

/* info
------------------------------------------------- */
.copy .info {
	color: #fff;
	display: inline-flex;
	flex-direction: column;
	justify-content: center;
	margin-top: 40px;
}
.copy .info dt {
	padding-right: 1em;
	padding-bottom: 4px;
}
.copy .info dd {
	border-bottom: 1px solid #ccc;
	padding-bottom: 6px;
}
.copy .info dd a {
	color: #fff;
	}
	@media screen and (min-width:1025px) {
	.copy .info {
		display: flex;
		flex-direction: row;
		justify-content: center;
		margin-top: 40px;
	}
	.copy .info dt {
		padding-right: 1em;
	}
	.copy .info dt,
	.copy .info dd {
		border-bottom: 1px solid #ccc;
		padding-bottom: 6px;
	}
}

/* データとビジョン
------------------------------------------------- */
.about.wrap {
		position: relative;
		z-index: 1;
		margin-top: -30px;
}
.about .bnr {
	width: 100%;
	position: relative;
	z-index: -7;
	background: #fff;
}
.about .bnr h2 {
	line-height: 1.1 !important;
	font-size: 2.4rem !important;
	margin-bottom: 12px;
}
.about .bnr.data {
	background: url(../images/bg_data.png) center right 35% no-repeat;
	background-size: cover;
}
.about .bnr.vision {
	background: url(../images/bg_vision.png) center left 45% no-repeat;
	background-size: cover;
	margin: 80px 0 80px;
	}
	@media screen and (min-width:1025px) {
	.about .bnr.vision {
		background: url(../images/bg_vision.png) top left 54% no-repeat;
		background-size: cover;
		margin: 80px 0 80px;
	}
}
.about .bnr::before {
	position: absolute;
	color: rgba(185, 223, 250, 0.4);
	font-family: 'Poppins', sans-serif;
	font-size: 8rem;
	font-weight: bold;
	line-height: 1;
	z-index: -1;
	top: -40px;
}
.about .bnr.data::before {
	left: -0.5em;
	content: "DATA";
}
.about .bnr.vision::before {
	right: -0.5em;
	content: "VISION";
}
.about .bnr a {
	display: block;
	position: relative;
	padding: 28px 24px 34px;
	color: #333;
}
.about .bnr.vision a {
	padding-left: 40%;
}
.about .bnr .btn {
	position: absolute;
	bottom: -23px;
	left: 24px;
	}
	@media screen and (min-width:1025px) {
	.about .bnr h2 {
		line-height: 1.3 !important;
		font-size: 4.8rem !important;
		margin-bottom: 0;
	}
	.about .bnr.vision {
		margin: 140px 0 200px;
	}
	.about .bnr::before {
		font-size: 25rem;
		top: -100px;
	}
	.about .bnr.data::before {
		left: -0.35em;
	}
	.about .bnr.vision::before {
		right: -0.35em;
	}
	.about .bnr a {
		padding: 50px 80px 70px;
	}
	.about .bnr.vision a {
		padding-left: 60%;
	}
	.about .bnr .txt {
		font-size: 2.4rem;
		line-height: 2;
		margin-top: 30px;
	}
	.about .bnr .btn {
		position: absolute;
		bottom: -34px;
		left: 80px;
	}
	.about .bnr.vision .btn {
		left: auto;
		right: 80px;
	}
}

/* インタビュー
------------------------------------------------- */
.itv {
	background: #fff;
	padding: 90px 0;
	position: relative;
	z-index: 1;
	overflow: hidden;
}
.itv::before {
	display: block;
	content: "";
	position: absolute;
	bottom: 0;
	right: 0;
	width: 100%;
	height: 100%;
	background: url(../cmn_images/logo_bg.svg) center bottom no-repeat;
	background-size: cover;
	opacity: 0.2;
	z-index: -2;
}
.itv h2::before {
	left: -0.5em !important;
	content: "INTERVIEW";
}
.itv .flex a {
	display: block;
	flex-basis: 100%;
	background: #fff;
	color: #333;
	box-shadow: 0px 0px 20px 11px rgba(118, 171, 209, 0.1);
	margin-bottom: 40px;
	padding-bottom: 30px;
}
.itv .flex a:last-of-type {
	margin-bottom: 0;
}
.itv .flex dl {
	display: flex;
	flex-direction: column;
}
.itv .flex dl dt {
	order: 2;
	font-size: 2.2rem;
	color: #1e7bc0;
	padding: 20px 24px 0;
}
.itv .flex dl dt span {
	display: block;
	font-size: 1.4rem;
	color: #333;
	line-height: 1.6;
	margin-top: 6px;
}
.itv .flex dl dd.txt {
	order: 3;
	font-size: 1.6rem;
	line-height: 1.5;
	padding: 16px 24px 0;
}
.itv .flex dl dd.pic {
	order: 1;
	overflow: hidden;
}
.itv .btnArea {
	text-align: center;
}
.itv .btnArea .btn {
	width: 300px;
	margin: 0 auto;
	}
	@media screen and (min-width:1025px) {
	.itv {
		padding: 230px 0 130px;
	}
	.itv::before {
		bottom: -8%;
		background: url(../cmn_images/logo_bg.svg) right -25% bottom no-repeat;
		background-size: auto 90%;
	}
	.itv h2::before {
		left: -0.35em !important;
		content: "INTERVIEW";
	}
	.itv .flex a {
		flex-basis: 30%;
		margin-bottom: 0;
		padding-bottom: 60px;
	}
	.itv .flex dl dt {
		font-size: 3.2rem;
		padding: 50px 12% 0;
	}
	.itv .flex dl dt span {
		font-size: 1.5rem;
		margin-top: 0;
	}
	.itv .flex dl dd.txt {
		font-size: 2.2rem;
		padding: 20px 12% 0;
	}
	.itv .btnArea .btn {
		width: 460px;
		margin: 90px auto 0;
	}
	.itv .flex a .pic img {
		transition: all .3s ease-out;
	}
	.itv .flex a:hover .pic img {
		-webkit-transform: scale(1.1);
		transform: scale(1.1);
	}
}

/* 採用情報
------------------------------------------------- */
.picBnr {
	position: relative;
	z-index: 1;
}
.recruit {
	background: #fff;
	padding: 90px 0 48px;
	width: 90%;
	position: relative;
	z-index: 1;
	margin-top: -40px;
}
.recruit .wrap {
	width: 80%;
	min-width: 80%;
}
.recruit h2::before {
	left: -60%;
	content: "RECRUIT";
}
.recruit .btn {
	width: 240px;
	margin: 0 auto 10px;
	}
	@media screen and (min-width:1025px) {
	.recruit {
		padding: 230px 0 130px;
		margin-top: -150px;
	}
	.recruit .btn {
		flex-basis: 31%;
		margin: 0 auto;
	}
	.recruit h2::before {
		left: -0.7em;
	}
}

/* for appear
============================ */
/* エリア */
.index .itv,
.index .recruit {
	opacity: 0;
	position: relative;
	top: 50px;
}
/* キャッチコピー */
.index video#bgvid,
.index .about a.data,
.picBnr,
.index .copy {
	opacity: 0;
}
/* リンクエリア */
.index .about a.vision, 
.index .itv .flex a {
	opacity: 0;
	position: relative;
	top: 40px;
}
/* リンクボタン */
.index .about .data p.btn {
	opacity: 0;
	left: 0;
}
.index .about .vision p.btn {
	opacity: 0;
	left: auto;
	right: 10%;
}
.index .about .data p.btn.is-active {
	opacity: 1;
	left: 5%;
}
.index .about .vision p.btn.is-active {
	opacity: 1;
	right: 5%;
	}
	@media screen and (min-width:1025px) {
	.index .about .data p.btn {
		opacity: 0;
		left: 50px;
	}
	.index .about .vision p.btn {
		opacity: 0;
		left: auto;
		right: 130px;
	}
	.index .about .data p.btn.is-active {
		opacity: 1;
		left:80px;
	}
	.index .about .vision p.btn.is-active {
		opacity: 1;
		right:80px;
	}
}
.index .itv a.btn,
.index .recruit .flex a {
	opacity: 0;
	position: relative;
	left: -30px;
}
.index .recruit .flex a.is-active,
.index .itv a.btn.is-active {
	opacity: 1;
	left:0;
}
