@charset "utf-8";



.col_w{
	color: #fff;
}

.btn-news{
	margin: 0 auto;
}



/* ---------------------------------------
* common
------------------------------------------ */



.btn.sp{
	display: none;
}

.col-w{
	color: #fff;
}

.access a{
	display: block;
	text-decoration: underline;
}



/* --------------------------------
* Top ページ
----------------------------------- */
.mv-wrapper{
	position: relative;
}

.mv-shape{
	position: absolute;
	width: 22.222%;
	max-width: 240px;
	right: 0;
	bottom: 7rem;
}

.mv-shape svg{
	width: 100%;
	height: 100%;
}

.mv-img{
	width: 100%;
	height: 520px;
	border-radius: 40px;
	background-repeat: no-repeat;
	background-size: cover;
	background-image: url(../img/top/mv.png);
}

.mv-txt{
	width: 62.5rem;
	max-width: 750px;
	margin-top: 20px;
	position: relative;
}

.mv-txtEn{
	width: 66.75rem;
	max-width: 801px;
}

.mv-txt p{
	width: 36rem;
	max-width: 442px;
	font-size: 16px;
	font-weight: 600;
	padding: 0.333rem;
	text-align: center;
	border: solid 1px #000;
	border-radius: 50px;
	letter-spacing: normal;
	line-height: 160%;
	position: absolute;
	right: 0;
	top: 30px;
}

.mv-txtEn p{
	width: 41.1rem;
	max-width: 494px;
}

.mv-txt h2{
	font-size: 95px;
	/* 	font-size: 7.9rem; */
	line-height: 100%;
	letter-spacing: normal;
	font-weight: 500;
}

.logoSlide{
	padding: 14px 0;
	background-color: #fff;
	overflow: hidden;
}

.logoSlideWrap{
	width: calc(1440px * 3);
}

.logoSlideImg{
	width: 1440px;
}


.sec01{
	margin-top: 10rem;
}

.about-wrapper{
	position: relative;
	width: 96.666%;
	max-width: 1200px;
	margin: 0 auto;
	background-color: #F8F7F4;
	border: #000 solid 1px;
	border-radius: 40px;
	padding: 80px 100px 100px;
}

.about-txtEn{
	width: 40rem;
	max-width: 480px;
}

.about-txt .ttl-wrapper{
	padding-bottom: 60px;
}

.about-txt h3{
	font-size: 32px;
	line-height: 140%;
	padding-bottom: 40px;
}

.about-txt h3,.about-txt h2{
	font-size: 32px;
}

.about-txt p{
	line-height: 240%;
	font-size: 16px;
}

.about-txtEn p{
	line-height: 260%;
	font-size: 16px;
}

.about-img{
	position: absolute;
	width: 45%;
	max-width: 560px;
	top: 50%;
	transform: translateY(-50%);
	right: 85px;
}

.txt-banner{
	overflow: hidden;
	padding: 137px 0 33px;
}

.banner-wrap{
	width: calc(186vw * 3);
}

.banner-img{
	display: inline-block;
	width: 183vw;
	margin-right: 2.5vw;
}

.sec02{
	padding-top: 100px;
	background-color: #000000;
}

.service-txtWrap{
	align-items: flex-end;
}

.service-txt{
	width: 33.3333%;
}

.service-txt h3{
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
	padding-bottom: 20px;
	font-family: "termina","Satoshi", sans-serif;
}

.service-txtEn h3{
	font-weight: 500;
}

.service-img{
	width: 61.111%;
}

.column-listItem{
	padding: 60px;
	border-radius: 40px;
	background-color: #fff;
}

.column-listItem:not(:last-of-type){
	margin-bottom: 40px;
}

.column-listImg{
	width: 37.5%;
}

.column-listTxt{
	padding-left: 120px;
	width: 50%;
	padding-top: 30px;
}

.column-listTxt h3{
	font-size: 18px;
	line-height: 160%;
	padding-bottom: 30px;
	font-weight: 600;
	letter-spacing: normal;
}

.partner-txt{
	width: 55.555%;
	margin-left: auto;
}

.partner-wrapper{
	padding: 80px 100px 64px;
	background: #000;
	border-radius: 40px;
}

.threeColumn-listItem{
	width: 31.4%;
}

.threeColumn-listTxt h3{
	font-size: 20px;
	line-height: 160%;
	letter-spacing: normal;
	padding-bottom: 20px;
	font-weight: 600;
}

.threeColumn02-list{
	column-gap: 2.777%;
	row-gap: 30px;
}

.threeColumn02-listItem{
	width: 31.4%;
	padding: 30px 20px;
	background-color: #F8F7F4;
	border-radius: 10px;
}

.threeColumn02-listItem-en{
	height: 280px;
}

.threeColumn02-listIcon{
	width: 20%;
}

.threeColumn02-ttl h3{
	font-weight: 600;
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
	padding-left: 20px;
}

.threeColumn02-txt{
	padding-top: 20px;
	font-size: 14px;
}

.sec06{
	background-color: #000;
	position: relative;
	padding-bottom: 88px;
}

.sec06-bg{
	position: absolute;
	left: 0;
	top: 0;
	width: 85.8%;
}

.sec06 .inner_l{
	position: relative;
	z-index: 2;
}

.location-detail h3{
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
}

.location-list{
	padding-top: 30px;
}

.location-listItem{
	width: 23.6%;
	padding: 40px 20px;
	border-radius: 10px;
	height: 340px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.mall{
	background-image: url(../img/top/loca01.png);
}

.studium{
	background-image: url(../img/top/loca02.png);
}

.hotel{
	background-image: url(../img/top/loca03.png);
}

.trans{
	background-image: url(../img/top/loca04.png);
}

.cvBanner{
	background-color: #fff;
	border-radius: 10px;
}

.cvBanner a{
	padding: 40px 60px;
	border-radius: 10px;
}

.cvBanner-l-en{
	width: 55%;
}

.cvBanner-l h3{
	font-weight: 600;
	font-size: 24px;
	line-height: 100%;
	letter-spacing: normal;
	padding-bottom: 10px;
}

.cvBanner-l p{
	font-weight: 600;
	letter-spacing: normal;
	font-size: 14px;
	color: #808080;
}

.cvBanner:hover .btn{
	background-color: #000;
}

.cvBanner:hover .btn span:first-of-type{
	color: #fff;
}

.cvBanner:hover .btn span:last-of-type path{
	stroke: #fff;
}

@media screen and (max-width:768px) {


	/* ---------------------------------------
	* common
	------------------------------------------ */
	body {
		font-size: 14px;
	}

	.tag-list{
		padding: 30px 0;
		row-gap: 20px;
		column-gap: 30px;
	}

	.tag-listItem a span:last-of-type{
		width: 20px;
		height: 20px;
	}

	.tag-listItem a span:last-of-type svg{
		width: 100%;
	}



	.btn.sp{
		display: flex;
	}

	.btn.pc{
		display: none;
	}

	.btn{
		margin: 0 auto;
	}

	main{
		overflow: hidden;
	}

	.btn.sp{
		display: none;
	}

	.btn.pc{
		display: block;
	}

	/* --------------------------------
	* Top ページ
	----------------------------------- */

	.mv-shape{
		width: 25%;
		bottom: 90px;
		max-width: 100%;
	}

	.mv-img{
		height: 240px;
		border-radius: 20px;
		background-position: center;
	}

	.mv-txt{
		width: 100%;
		margin-top: 20px;
		position: relative;
	}

	.mv-txt p{
		width: 100%;
		font-size: 14px;
		font-weight: 600;
		padding: 2px;
		position: static;
		margin-top: 10px;
	}

	.mv-txtEn p{
		font-size: 10px;
	}

	.mv-txt h2{
		font-size: 42px;
	}
	
		.logoSlide{
		padding: 14px 0;
	}

	.logoSlideWrap{
		width: calc(800px * 3);
	}

	.logoSlideImg{
		width: 800px;
	}

	.sec01{
		overflow: hidden;
		margin-top: 80px;
	}

	.about-wrapper{
		width: calc(100% - 40px);
		border-radius: 20px;
		padding: 60px 30px 220px;
	}

	.about-txtEn{
		width: 100%;
	}

	.about-txt .ttl-wrapper{
		padding-bottom: 50px;
	}

	.about-txt h3{
		font-size: 28px;
		padding-bottom: 30px;
	}

	.about-txt h3,.about-txt h2{
		font-size: 24px;
	}

	.about-txt p{
		font-size: 14px;
	}

	.about-img{
		position: absolute;
		width: 115%;
		top: unset;
		transform: unset;
		bottom: 40px;
		right: -7%;
	}

	.txt-banner{
		padding: 80px 0 20px;
	}

	.banner-wrap{
		width: calc(214vw * 3);
	}

	.banner-img{
		width: 210vw;
		margin-right: 3vw;
	}

	.sec02{
		padding-top: 80px;
	}

	.service-txtWrap{
		display: flex;
		flex-direction: column-reverse;
	}

	.service-txt{
		width: 100%;
		padding-top: 30px;
	}


	.service-img{
		width: 100%;
	}

	.column-listItem{
		padding: 30px;
		border-radius: 20px;
	}

	.column-listItem:not(:last-of-type){
		margin-bottom: 40px;
	}

	.column-listImg{
		width: 100%;
	}

	.column-listTxt{
		width: 100%;
		padding-top: 30px;
		padding-left: 0;
	}

	.column-listTxt h3{
		padding-bottom: 20px;
	}

	.partner-txt{
		width: 100%;
	}

	.partner-wrapper{
		padding: 40px 30px;
		border-radius: 20px;
	}

	.partner-figureWrap{
		overflow: hidden;
	}

	.partner-figure{
		width: 200%;
	}

	.threeColumn-listItem{
		width: 100%;
	}

	.threeColumn-listItem:not(:last-of-type){
		margin-bottom: 40px;
	}

	.threeColumn-listTxt h3{
		font-size: 18px;
	}

	.threeColumn02-listItem{
		width: 100%;
	}

	.threeColumn02-listItem-en {
		height: auto;
	}

	.threeColumn02-listItem:not(:last-of-type){
		margin-bottom: 30px;
	}


	.sec06{
		padding-bottom: 80px;
	}

	.sec06-bg{
		width: 100%;
	}


	.location-listItem{
		width: 100%;
		padding: 30px 20px;
		height: 200px;
	}

	.location-listItem:not(:last-of-type){
		margin-bottom: 30px;
	}


	.cvBanner a{
		padding: 40px 30px;
	}

	.cvBanner-l{
		padding-bottom: 30px;
	}

	.cvBanner-l-en{
		width: 100%;
	}

	.cvBanner-l h3{
		font-size: 24px;
		text-align: center;
	}

	.cvBanner-l p{
		text-align: center;
	}


}

.cv-area{
	background-color: #000;
	border-radius: 20px;
	padding: 60px 100px 80px;
	margin-bottom: 132px;
}

.cv-ttl{
	font-size: 64px;
	font-weight: 500;
	line-height: 100%;
	letter-spacing: normal;
}

.cv-listItem{
	width: 46.6666%;
}

.cv-listItem p{
	font-weight: 600;
}

.cvTxt{
	padding-top: 10px;
	font-size: 14px;
}

.cv-listItem a{
	justify-content: center;
	padding: 30px;
	border-radius: 10px;
	background-color: #fff;
	border: 1px #fff solid;
	margin-top: 14px;
	transition: all .3s;
}

.cv-listItem a:hover{
	background-color: #000;
	color: #fff;
}

.cv-listItem02 a{
	background-color: #25D366;
	border: 1px #25D366 solid;
}

.cv-listItem02 a:hover{
	color: #25D366;
}

.cv-listItem a span{
	display: inline-block;
	vertical-align: middle;
}

.cv-listItem a span:first-of-type{
	font-weight: 600;
	line-height: 100%;
	margin-right: 10px;
}

.cv-listItem a span:last-of-type{
	width: 20px;
	height: 20px;
	position: relative;
}

.cv-listItem a span:last-of-type svg{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}

.cv-listItem a path{
	transition: all .3s;
}

.cv-listItem a:hover path{
	stroke: #fff;
}

.cv-listItem02 a:hover path{
	stroke: #25D366;
}

.cv-area.none{
	display: none;
}

.form-tel{
	padding: 30px 60px;
	background-color: #F4F4F4;
	border-radius: 10px;
}

.form-tel h4{
	font-weight: 600;
	font-size: 20px;
	line-height: 160%;
	letter-spacing: normal;
}

.form-tel>p{
	font-size: 14px;
	padding-top: 4px;
	letter-spacing: normal;
}

.tel-num{
	justify-content: center;
	padding-top: 10px;
}

.tel-icon{
	width: 34px;
	height: 34px;
}

.tel-icon svg{
	width: 100%;
	height: 100%;
}

.tel-num a{
	display: block;
	font-weight: 600;
	margin-left: 10px;
	font-size: 2.4rem;
	line-height: 160%;
	letter-spacing: 0.02em;
}



@media screen and (max-width:768px) {

	.cv-area{
		padding: 60px 30px 80px;
		margin-bottom: 100px;
	}

	.cv-ttl{
		font-size: 42px;
	}

	.cv-listItem{
		width: 100%;
	}

	.cv-listItem:first-of-type{
		margin-bottom: 30px;
	}

	.cv-listItem a{
		padding: 20px 0;
		margin-top: 14px;
	}


	.form-tel{
		padding: 20px ;
	}

	.form-tel h4{
		font-size: 18px;
	}

	.form-tel>p{
		font-size: 12px;
	}


	.tel-icon{
		width: 28px;
		height: 28px;
	}

	.tel-num a{
		font-size: 24px;
	}



}