@charset "UTF-8";

.l-content_inner {
	margin: 0 auto;
	padding: 0 20px;
	width: 1320px;
	max-width: 100%;
}
.anchor-pos {
	margin-top: -150px;
	padding-top: 150px;
}
/* --------------------------------------------------
	ファーストビュー
-------------------------------------------------- */
.main-visual {
	margin: -250px 0 30px;
	padding-top: 250px;
	background: url(../img/top/bg_main.png) no-repeat center bottom,radial-gradient(#000,#111);
	overflow: hidden;
}
.main-visual_body {
	position: relative;
	display: flex;
	align-items: center;
	margin: 0 auto;
	padding: 0 20px;
	width: 1350px;
	max-width: 100%;
	height: 750px;
	max-height: 38.2vw;
}
h1 {
	padding-bottom: 8%;
	max-width: 48%;
}
.main-visual_cont {
	position: absolute;
	top: 56%;
	right: -150px;
	width: 909px;
	max-width: 68%;
	transform: translate(0,-50%);
}
.main-visual_cont_bg {
	display: block;
	width: 100%;
}
.main-visual_cont_shape {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	width: 100%;
}
.main-visual_video {
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	mask: url(../img/top/bg_main_shape.svg) no-repeat;
	mask-size: 100% auto;
}
/* --------------------------------------------------
	News
-------------------------------------------------- */
.news {
	display: flex;
	margin-bottom: 300px;
}
.news_ttl {
	font-size: 16px;
	font-weight: normal;
}
.news_list {
	flex: 1;
	position: relative;
	padding-left: 20px;
}
.news_list:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 10px;
	width: 1px;
	height: 100%;
	background-color: #d10000;
	transform: translate(0,-50%);
}
.news_item {
	display: flex;
	margin-bottom: 5px;
}
.news_item:last-child {
	margin-bottom: 0;
}
.news_item_date {
	margin-right: 1em;
	white-space: nowrap;
}
.news_item_txt {
	flex: 1;
}
/* --------------------------------------------------
	メッセージ
-------------------------------------------------- */
.message {
	margin-bottom: 300px;
}
.message_cont {
	display: flex;
	margin-bottom: 100px;
}
.message_cont:last-child {
	margin-bottom: 0;
}
.message_cont_body {
	flex: 1;
	padding-right: 40px;
}
.message_cont_ttl {
	margin-bottom: 65px;
	line-height: 1.4;
	font-size: 36px;
	font-weight: normal;
}
.message_cont_txt {
	margin-bottom: 1em;
}
.message_cont_txt:last-child {
	margin-bottom: 0;
}
.message_cont_img {
	width: 640px;
	max-width: 50%;
	height: 443px;
	border-radius: 200px 0 200px 0;
	overflow: hidden;
}
.message_cont_img video {
	position: relative;
	left: 50%;
	width: auto;
	height: 100%;
	transform: translate(-50%,0);
}
/* --------------------------------------------------
	特徴
-------------------------------------------------- */
.feature {
	margin-bottom: 300px;
}
.feature_body {
	position: relative;
}
.feature .l-content_inner {
	position: relative;
	z-index: 1;
	background-color: #111;
}
.feature_bg {
	clip-path: inset(0);
	position: absolute;
	top: 12px;
	left: 0;
	width: 100%;
	height: calc(100% - 13px);
	overflow: hidden;
}
.parallax-img {
	position: fixed;
	top: 0;
	left: 0;
}
.parallax-img--02 {
	left: auto;
	right: 0;
}
.feature .l-content_inner {
	padding: 0 80px;
	width: 1440px;
}
.feature_list {
	display: flex;
	flex-wrap: wrap;
}
.feature_item {
	margin: 0 80px 60px 0;
	width: 600px;
}
.feature_item:nth-child(2n) {
	margin-right: 0;
}
.feature_item:nth-last-child(2),
.feature_item:last-child {
	margin-bottom: 0;
}
.feature_item_ttl {
	display: flex;
	align-items: center;
	margin-bottom: 22px;
	font-size: 28px;
	font-weight: bold;
}
.feature_item_num {
	width: 100px;
	height: 100px;
	line-height: 100px;
	border: 1px solid #FFF;
	text-align: center;
}
.feature_item_ttl_txt {
	flex: 1;
	padding-left: 20px;
}
/* --------------------------------------------------
	投資領域、会社概要
-------------------------------------------------- */
.overview {
	margin-bottom: 300px;
}
.overview_txt {
	margin-bottom: 26px;
}
.overview table {
	width: 100%;
}
.overview tr {
	border-top: 1px solid #FFF;
	border-bottom: 1px solid #FFF;
}
.overview td {
	padding: 30px 50px 30px 0;
	line-height: 1.4;
}
.overview td:first-child {
	padding: 30px 50px;
	width: 320px;
	vertical-align: top;
}
/* --------------------------------------------------
	メンバー
-------------------------------------------------- */
.member {
	margin-bottom: 300px;
}
.member_cont {
	position: relative;
}
.member_img {
	display: block;
	margin: 0 auto;
}
.member_list {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 30px;
	width: 100%;
	height: 100%;
	color: #111;
}
.member_list li {
	width: 270px;
}
.member_list li:nth-child(2) {
	text-align: right;
}
.member_list_subttl {
	margin-bottom: 10px;
}
.member_list_name {
	margin-bottom: 15px;
	font-size: 28px;
	font-weight: bold;
}
/* --------------------------------------------------
	投資実績
-------------------------------------------------- */
.portfolio {
	margin-bottom: 300px;
}
.portfolio_cont {
	margin-bottom: 95px;
}
.portfolio_cont_ttl {
	margin-bottom: 56px;
	font-size: 28px;
}
.portfolio_cont_list {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.portfolio_cont_list li {
	margin-right: 4%;
	width: 22%;
	background-color: #FFF;
	box-shadow: 0 0 30px rgba(255,255,255,.5);
}
.portfolio_cont_list li:nth-child(4n) {
	margin-right: 0;
}
.portfolio_cont_list li:nth-last-child(n+5) {
	margin-bottom: 50px;
}
.portfolio_cont_list a {
	display: block;
	box-shadow: 0 0 5px #FFF;
	text-decoration: none;
	color: #FFF;
	transition: .2s linear;
}
.portfolio_cont_list_body {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 270px;
}
.portfolio_cont_list_logo {
	transition: .2s linear;
}
.portfolio_cont_list a:hover .portfolio_cont_list_logo {
	transform: scale(1.2);
}
.portfolio_cont_list_txt {
	position: relative;
	padding: 19px 70px 19px 10px;
	background-color: #000;
	text-align: center;
}
.portfolio_cont_list_icon {
	position: absolute;
	top: 50%;
	right: 15px;
	width: 40px;
	height: 20px;
	background-color: #FFF;
	border-radius: 10px;
	transform: translate(0,-50%);
	transition: .2s linear;
}
.portfolio_cont_list_icon:before {
	position: absolute;
	content: "";
	top: 50%;
	left: 50%;
	width: 11px;
	height: 11px;
	background: url(../img/top/icon_arrow.png) no-repeat;
	background-size: 11px auto;
	transform: translate(-50%,-50%);
}
.portfolio_cont_list a:hover .portfolio_cont_list_icon {
	transform: translate(0,-50%) scale(1.2);
}
/* --------------------------------------------------
	お問い合わせ
-------------------------------------------------- */
.contact {
	margin-bottom: 200px;
}
.contact_txt {
	margin-bottom: 60px;
}
.contact_more {
	text-align: center;
}
.contact_more_link {
	position: relative;
	display: inline-block;
	padding: 29px 60px;
	width: 400px;
	max-width: 100%;
	border-radius: 50px;
	font-size: 28px;
	font-weight: bold;
	text-decoration: none;
	color: #FFF;
}
.contact_more_link:before {
	position: absolute;
	content: "";
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 1px solid #FFF;
	border-radius: 50px;
	box-sizing: border-box;
	transition: .2s linear;
}
.contact_more_link:hover:before {
	border-width: 3px;
}
.contact_more_link:after {
	position: absolute;
	content: "";
	top: 50%;
	right: 40px;
	width: 30px;
	height: 30px;
	background: url(../img/top/icon_arrow_white.png) no-repeat -30px 50%;
	background-size: 23px auto;
	transform: translate(0,-50%);
	transition: .2s linear;
}
.contact_more_link:hover:after {
	background-position: 50% 50%;
}
/* --------------------------------------------------
	画面幅別
-------------------------------------------------- */
@media screen and (max-width: 1440px) {
	/*---------- ファーストビュー ----------*/
	.main-visual_cont {
		right: -40px;
		max-width: 60%;
	}
	/*---------- 特徴 ----------*/
	.feature .l-content_inner {
		padding: 0 20px;
	}
	.feature_item {
		margin-right: 4%;
		width: 48%;
	}
	.feature_item:nth-last-child(2),
	.feature_item:last-child {
		margin-bottom: 130px;
	}
	.feature_bg {
		position: relative;
		top: 0;
		height: 400px;
	}
	.parallax-img {
		left: 50%;
		width: auto;
		min-width: 100%;
		max-width: none;
		min-height: 100%;
		transform: translate(-50%,0);
	}
	.parallax-img--02 {
		display: none;
	}
}
@media screen and (max-width: 1200px) {
	/*---------- メッセージ ----------*/
	.message_cont {
		align-items: flex-end;
	}
}
@media screen and (max-width: 980px) {
	/*---------- ファーストビュー ----------*/
	.main-visual {
		margin: -50px 0 20px;
		padding-top: 50px;
		background-image: url(../img/top/bg_main_sp.png);
	}
	.main-visual_body {
		display: block;
		height: auto;
		max-height: none;
		overflow: hidden;
	}
	h1 {
		margin: 0 auto 20px;
		padding: 80px 0 0;
		max-width: 400px;
		text-align: center;
	}
	.main-visual_cont {
		position: relative;
		top: auto;
		left: 50%;
		padding-bottom: 10px;
		width: 135%;
		max-width: 460px;
		transform: translate(-50%,0);
	}
	.main-visual_video {
		mask-image: url(../img/top/bg_main_shape_sp.svg);
	}
	/*---------- News ----------*/
	.news {
		margin-bottom: 120px;
	}
	/*---------- メッセージ ----------*/
	.message {
		margin-bottom: 100px;
	}
	.message_cont {
		display: block;
	}
	.message_cont_body {
		margin-bottom: 50px;
		padding-right: 0;
	}
	.message_cont_ttl {
		margin-bottom: 52px;
		font-size: 20px;
		font-weight: bold;
	}
	.message_cont_img {
		display: block;
		margin: 0 auto;
		width: 100%;
		max-width: 100%;
		height: auto;
		border-radius: 100px 0 100px 0;
	}
	.message_cont_img video {
		display: block;
		width: 100%;
	}
	/*---------- 特徴 ----------*/
	.feature {
		margin-bottom: 120px;
	}
	/*---------- 投資領域、会社概要 ----------*/
	.overview {
		margin-bottom: 120px;
	}
	.overview_txt {
		margin-bottom: 50px;
	}
	.overview td {
		display: block;
		padding: 0 0 20px;
		width: 100%;
	}
	.overview td:first-child {
		padding: 20px 0 5px;
		width: 100%;
		font-weight: bold;
	}
	/*---------- メンバー ----------*/
	.member {
		margin-bottom: 120px;
	}
	.member_cont picture {
		position: relative;
		left: -20px;
		display: block;
		width: calc(100% + 40px);
	}
	.member_img {
		margin-bottom: 20px;
		height: 250px;
		min-height: 62vw;
		object-fit: cover;
	}
	.member_list {
		position: static;
		align-items: flex-start; /* 実機でのレイアウト調整 */
		padding: 0;
		color: #FFF;
	}
	.member_list li {
		width: 45%;
	}
	.member_list li:first-child {
		margin-right: 5%;
		padding-bottom: 0;
	}
}
@media screen and (max-width: 768px) {
	.anchor-pos {
		margin-top: -100px;
		padding-top: 100px;
	}
	/*---------- 特徴 ----------*/
	.feature .l-content_inner {
		padding: 0 20px;
	}
	.feature_list {
		display: block;
	}
	.feature_item {
		margin: 0 0 50px;
		width: auto;
	}
	.feature_item:nth-last-child(2),
	.feature_item:last-child {
		margin-bottom: 50px;
	}
	.feature_item_ttl {
		margin-bottom: 30px;
	}
	.feature_item_num {
		width: 60px;
		height: 60px;
		line-height: 60px;
	}
	.feature_item_ttl_txt {
		line-height: 1.3;
		font-size: 24px;
	}
	/*---------- 投資実績 ----------*/
	.portfolio {
		margin-bottom: 100px;
	}
	.portfolio_cont_ttl {
		margin-bottom: 36px;
		font-size: 24px;
	}
	.portfolio_cont_list li {
		margin-right: 4%;
		width: 48%;
	}
	.portfolio_cont_list li:nth-child(2n) {
		margin-right: 0;
	}
	.portfolio_cont_list li:nth-child(n+3) {
		margin-top: 30px;
	}
	.portfolio_cont_list_body {
		height: 200px;
	}
	/*---------- お問い合わせ ----------*/
	.contact_more_link {
		padding: 25px 20px;
		width: 300px;
		font-size: 24px;
	}
	.contact_more_link:after {
		display: none;
	}
}
@media screen and (max-width: 425px) {
	/*---------- ファーストビュー ----------*/
	.main-visual_cont {
		left: -4%;
		transform: none;
	}
}