@charset "utf-8";
/* -----------------------------------------------
= common
----------------------------------------------- */
body {
	position: relative;
	opacity: 0;
	transition: opacity .8s;
}
body.visible {
	opacity: 1;
}
body::before,
body::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: -3;
	width: 100%;
	height: 100%;
	background: linear-gradient(#e9dde4 0,#cfe1e3 50%,#e1dbe3 80%,#e0dbe3 100%);
}
/* -----------------------------------------------
= main_contents
----------------------------------------------- */
.main_contents {
	position: relative;
	margin-bottom: -14rem;
	padding-bottom: 14rem;
}
.main_contents::before,
.main_contents::after {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.main_contents::before {
	z-index: -2;
	background: url(../../img/nanimono/interview_bg01.png) repeat-y 50% 0;
}
.main_contents::after {
	z-index: -1;
	background: url(../../img/shared/bg01.png?230130);
	mix-blend-mode: multiply;
}
@media print, screen and (min-width: 768px) {/* PC */
.main_contents {
	margin-bottom: -28.6rem;
	padding-bottom: 28.6rem;
}
}/* @media */
/* -----------------------------------------------
= pagetitle
----------------------------------------------- */
.pagetitle {
	position: relative;
	height: 20.7rem;
	padding: 8rem 0 0;
	color: #fff;
	text-align: center;
	letter-spacing: .06em;
	overflow: hidden;
}
.pagetitle .inner::before,
.pagetitle .inner::after {
	content: '';
	position: absolute;
	background: url(../../img/project/index_pagetitle.jpg) no-repeat 50% / cover;
}
.pagetitle .inner::before {
	top: 8.1rem;
	right: 50%;
	width: calc(50% + 4rem);
	height: 14.4rem;
	margin-right: -4rem;
	clip-path: polygon(0 100%, 0 0, 100% 0, 64.3% 100%);
}
.pagetitle .inner::after {
	top: 11.5rem;
	left: 2.5rem;
	width: calc(100% - 2.5rem);
	height: 14.6rem;
	clip-path: polygon(0 100%, 22.6% 0, 100% 0, 100% 100%);
}
.pagetitle h1 .en {
	display: block;
	position: relative;
	z-index: 1;
	padding: 7.5rem 0 1.8rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 2.4rem;
}
.pagetitle h1 .jp {
	display: block;
	position: relative;
	z-index: 1;
	padding: 0 0 1.2rem;
	font-size: 1.4rem;
}
@media print, screen and (min-width: 768px) {/* PC */
.pagetitle {
	height: 59.2rem;
	padding: 11.3rem 0 0;
}
.pagetitle::before {
	content: '';
	position: absolute;
	top: 14.2rem;
	left: 50%;
	margin-left: -12.7rem;
	width: 59.1rem;
	height: 53.5rem;
	background: url(../../img/project/index_bg01.png) no-repeat 0 0 / cover;
}
.pagetitle .inner::before {
	top: 11.3rem;
	width: calc(50% + 8.5rem);
	height: 51.2rem;
	margin-right: -8.5rem;
}
.pagetitle .inner::after {
	top: auto;
	bottom: 0;
	left: 50%;
	width: calc(50% + 65rem);
	height: 52rem;
	margin-left: -65rem;
	background-position: 12% 50%;
}
.pagetitle h1 .en {
	padding: 25rem 0 2.8rem;
	font-size: 5.7rem;
}
.pagetitle h1 .jp {
	padding: 0 0 1.8rem;
	font-size: 1.8rem;
}
}/* @media */
@media print, screen and (max-width: 1440px) and (min-width: 768px) {/* TABLET */
.pagetitle .inner::after {
	left: 7rem;
	width: calc(100% - 7rem);
	margin-left: 0;
}
}/* @media */
/* -----------------------------------------------
= search
----------------------------------------------- */
.search {
	position: relative;
	margin: 2rem 2rem 3rem;
	padding: 6rem 3rem .1rem;
	color: #fff;
	background: url(../../img/project/index_bg02.png) no-repeat 50% 0 / cover;
	opacity: 0;
	transform: translateY(4rem);
	transition: .8s .4s;
}
.search.visible {
	opacity: 1;
	transform: translateY(0);
}
.search button {
	color: #fff;
}
.search .reset {
	position: absolute;
	top: .8rem;
	right: .8rem;
}
.search .reset button {
	width: 12rem;
	height: 2.6rem;
	padding-right: 2rem;
	color: #918eb1;
	background: #fff;
	border-radius: .2rem;
	font-size: 1.2rem;
	letter-spacing: .02em;
	transition: opacity .3s;
}
.search .reset button:hover {
	opacity: .8;
}
.search .reset button::before,
.search .reset button::after {
	content: '';
	position: absolute;
	top: 50%;
	right: .5rem;
	width: .8rem;
	height: .1rem;
	background: #9590b1;
	text-align: left;
}
.search .reset button::before {
	transform: rotate(-45deg);
}
.search .reset button::after {
	transform: rotate(45deg);
}
.search .subtitle {
	display: flex;
	align-items: flex-end;
	margin-bottom: 4rem;
	padding-bottom: 1rem;
	border-bottom: .1rem solid rgba(255,255,255,.3);
	letter-spacing: .06em;
}
.search .subtitle .en {
	margin-right: 1em;
	font-family: 'Montserrat', sans-serif;
	font-size: 2rem;
}
.search .subtitle .jp {
	font-size: 1.2rem;
}
.search dt {
	margin-bottom: 1rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.4rem;
	letter-spacing: .02em;
}
.search dd {
	margin: 0 -.5rem 2rem;
}
.search dd li {
	display: inline-block;
	margin: 0 .5rem 1rem;
}
.search dd li button {
	padding: 0 1rem;
	border: .1rem solid #fff;
	border-radius: .2rem;
	font-size: 1.2rem;
	line-height: 2.4rem;
	letter-spacing: .02em;
	transition: .3s;
}
.search dd li button.is-selected {
	color: #918eb1;
	background: #fff;
}
.search dd li button:hover {
	color: #918eb1;
	background: #fff;
}
@media print, screen and (min-width: 768px) {/* PC */
.search {
	max-width: 103rem;
	margin: -6.5rem auto 8.7rem;
	padding: 5rem 3rem 2.41rem;
}
.search .reset {
	position: static;
	max-width: 96rem;
	margin: 0 auto 2rem;
	overflow: hidden;
}
.search .reset button {
	float: right;
	position: relative;
	width: 16.8rem;
	height: 3.1rem;
	padding-right: 2rem;
	font-size: 1.4rem;
}
.search .reset button::before,
.search .reset button::after {
	width: 1rem;
}
.search .subtitle {
	max-width: 96rem;
	margin: 0 auto 1.6rem;
	padding-bottom: 2rem;
}
.search .subtitle .en {
	margin-right: 1em;
	font-size: 3rem;
}
.search .subtitle .jp {
	font-size: 1.5rem;
}
.search dl {
	display: flex;
	max-width: 96rem;
	margin: 0 auto 2.6rem;
}
.search dt {
	width: 14rem;
	margin: .8rem 0;
	font-size: 1.8rem;
}
.search dd {
	flex: 1;
	margin: 0;
}
.search dd li {
	margin: 0 .5rem 1rem;
}
.search dd li button {
	font-size: 1.4rem;
	line-height: 2.8rem;
}
}/* @media */
/* -----------------------------------------------
= index_wrap
----------------------------------------------- */
.index_wrap {
	position: relative;
	padding: 0 2rem 2rem;
	overflow: hidden;
}
.index_wrap .item {
	margin: 0 0 3rem;
}
.index_wrap .item a {
	display: block;
	position: relative;
	color: #fff;
	letter-spacing: .02em;
}
.index_wrap .item a::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
}
.index_wrap .item.type01 a::before {
	height: 12.7rem;
	background: url(../../img/project/index_bg03.jpg?240222) no-repeat 50% / cover;
}
.index_wrap .item.type02 a::before {
	height: 10rem;
	background: url(../../img/project/index_bg04.jpg) no-repeat 50% / cover;
}
.index_wrap .item img {
	width: calc(100% - 5.2rem);
	margin-left: 5.2rem;
	object-fit: cover;
	object-position: 50% 20%;
}
.index_wrap .item.type01 img {
	height: 11.8rem;
}
.index_wrap .item.type01 .newbusiness img {
	object-position: 50% 70%;
}
.index_wrap .item.type01 .umekita img {
	object-position: 50% 10%;
}
.index_wrap .item.type01 .izumi img {
	object-position: 50% 50%;
}
.index_wrap .item.type01 .sydney img {
	object-position: 50% 0;
}
.index_wrap .item.type02 img {
	height: 11rem;
}
.index_wrap .item.type02 #modal_hilton-okinawa-miyako-island-resort img {
	object-position: 50% 70%;
}
.index_wrap .item.type02 #modal_mtfuji-shizuoka-airport img {
	object-position: 50% 90%;
}
.index_wrap .item.type02 #modal_marunouchi-hokenshitsu img,
.index_wrap .item.type02 #modal_spacemotion img,
.index_wrap .item.type02 #modal_act-5 img,
.index_wrap .item.type02 #modal_machi-pass img,
.index_wrap .item.type02 #modal_5g-infrastructure-sharing img,
.index_wrap .item.type02 #modal_hometact img,
.index_wrap .item.type02 #modal_yau img,
.index_wrap .item.type02 #modal_bricks-fund-tokyo img {
	object-position: 50% 50%;
}
.index_wrap .item.type02 #modal_tmdu-innovation-park img {
	object-position: 60% 50%;
}
.index_wrap .item .num {
	display: inline-block;
	position: absolute;
	left: 0;
	z-index: 1;
	padding: 0 1rem;
	font-family: 'Montserrat', sans-serif;
	font-size: 1.2rem;
	line-height: 2.7rem;
}
.index_wrap .item.type01 .num {
	top: 9.15rem;
	background: rgba(79,157,190,.8);
}
.index_wrap .item.type02 .num {
	top: 8.35rem;
	background: rgba(44,131,168,.8);
}
.index_wrap .item .tag {
	display: block;
	position: relative;
	padding: 1rem 1rem .5rem;
	font-size: 1.1rem;
}
.index_wrap .item .jp {
	display: block;
	position: relative;
	padding: .5rem 1rem;
	font-size: 1.2rem;
	line-height: 1.92em;
}
.index_wrap a img {
	filter: grayscale(100%);
	transition: filter .5s;
}
.index_wrap a:hover img {
	filter: grayscale(0);
}
@media print, screen and (min-width: 768px) {/* PC */
.index_wrap {
	display: flex;
	flex-wrap: wrap;
	max-width: 113.4rem;
	margin: 0 auto;
	padding: 1rem 0 0;
}
.index_wrap .item {
	margin: 0 2.1rem 3rem;
}
.index_wrap .item.type01 {
	width: 52.4rem;
	min-height: 16.4rem;
}
.index_wrap .item.type02 {
	width: 24.1rem;
}
.index_wrap .item.type01 a {
	display: flex;
	align-items: center;
}
.index_wrap .item.type01 a::before {
	height: 100%;
}
.index_wrap .item.type02 a::before {
	height: 14.4rem;
}
.index_wrap .item.type01 .set {
	order: 1;
	flex: 1;
}
.index_wrap .item.type01 .img {
	order: 2;
	width: 24rem;
}
.index_wrap .item.type01 img {
	width: 100%;
	height: auto;
	height: 16.4rem;
	margin-left: 0;
}
.index_wrap .item.type02 img {
	width: calc(100% - 2.6rem);
	height: 14.6rem;
	margin-left: 2.6rem;
}
.index_wrap .item.type01 .num {
	top: -1em;
	font-size: 1.3rem;
}
.index_wrap .item.type02 .num {
	top: 11.9rem; 
}
.index_wrap .item .tag {
	padding: 1rem 1.5rem;
	font-size: 1.2rem;
}
.index_wrap .item.type01 .jp {
	padding: 0 .5rem 0 1.5rem;
	font-size: 1.4rem;
	line-height: 2.24rem;
}
.index_wrap .item.type02 .jp {
	padding: .5rem 1rem;
}
.index_wrap .item.type02 .jp.small {
	font-size: 1rem;
}
}/* @media */
/* -----------------------------------------------
= modal
----------------------------------------------- */
.modal-backdrop {
	background-color: rgba(29,29,29,.9);
}
.modal.fade .modal_in {
	padding: 7.5rem 2.5rem 0;
}
.modal_btn_close {
	top: 4rem;
	right: 2.5rem;
}
.modal .inner {
	color: #fff;
}
.modal .name {
	margin-bottom: 1rem;
	font-size: 1.6rem;
	line-height: 1.3;
}
.modal .data {
	margin-bottom: 2rem;
	font-size: 1.2rem;
	line-height: 1.3;
}
.modal .text {
	margin-bottom: 3rem;
	font-size: 1.3rem;
	line-height: 2;
}
@media print, screen and (min-width: 768px) {/* PC */
.modal.fade .modal_in {
	max-width: 115.7rem;
	margin: 0 auto;
	padding: 12rem 4rem 0;
}
.modal_btn_close {
	top: 8rem;
	right: 4rem;
}
.modal .name {
	margin-bottom: 1rem;
	font-size: 3rem;
}
.modal .data {
	margin-bottom: 1rem;
	font-size: 1.4rem;
}
.modal .data {
	margin-bottom: 8.4rem;
}
.modal .inner .set {
	display: flex;
}
.modal .inner .set .text {
	flex: 1;
	margin-right: calc(56 / 1440 * 100vw);
}
.modal .inner .set .img {
	max-width: calc(728 / 1440 * 100vw);
}
}/* @media */

/* -----------------------------------------------
= print
----------------------------------------------- */
@media print {
body,
.profile .subtitle,
.profile .item,
.profile .note,
.block .subtitle .num,
.block .subtitle .title,
.block .set .item,
.block .img,
.block .note,
.column .img01,
.column .subtitle,
.column .logo,
.column .item,
.index_wrap .subtitle,
.index_wrap .item {
	opacity: 1;
	transform: translateY(0);
}
}/* @media */

