@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
	position: relative;
	height: 100vh;
	overflow: hidden;
}
.mv-video {
	position: absolute;
	top: 50%;
	left: 50%;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto;
	transform: translate(-50%, -50%) scale(1.1);
	object-fit: cover;
	z-index: -2;
}
.mv-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.4);
	z-index: -1;
}
.mv-inner {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: column;
	max-width: 1140px;
	width: 100%;
	height: 100%;
	margin-left: auto;
	margin-right: auto;
	padding-left: 22px;
	padding-right: 22px;
}
.mv-inner h1 {
	margin-bottom: 4rem;
	font-weight: normal;
	font-size: 4.2rem;
	color: white;
}
.mv-inner span {
	font-size: 2.2rem;
	color: white;
}
.circle-link {
	position: absolute;
	right: -100px;
	bottom: 72px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 144px;
	height: 144px;
	margin-right: 24px;
	background-image: url(../img/index/bg-btn.jpg);
	background-size: cover;
	background-repeat: none;
	border: 2px solid white;
	border-radius: 50%;
}
.circle-link:hover {
	opacity: 0.7;
}
.mv-inner span.circle-text {
	font-family: "Jost", sans-serif;
	font-size: 16px;
	color: white;
	letter-spacing: 0.08em;
}
.circle-btn {
	position: absolute;
	right: 0;
	bottom: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	background-color: #292929;
	border-radius: 50%;
}
.circle-btn img {
	width: 7px;
	height: 10px;
}

.mainVisual .scroll {
	padding-left: 0.5rem;
	font-size: 1.8rem;
	font-weight: 700;
	position: absolute;
	left: 3rem;
	bottom: 15rem;
	-ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: vertical-rl;
}
.mainVisual .scroll a::after {
	margin: 0 auto;
	display: inline-block;
	position: absolute;
	right: 0;
	bottom: -12rem;
	left: 2px;
	z-index: 2;
	width: 2px;
	transition: .2s;
	overflow: hidden;
}
.mainVisual .scroll a::before {
	content: '';
	position: absolute;
	bottom: -12rem;
	left: 50%;
	width: 2px;
	height: 10rem;
	background: #ddd;
}
.scroll a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 2px;
	height: 10rem;
	background: #000;
}
.scroll a:hover {
	opacity: 0.7;
}
.scroll a::after {
	animation: sdl01 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl01 {
	0% {
		transform: scale(1, 0);
		transform-origin: 0 0;
	}
	50% {
		transform: scale(1, 1);
		transform-origin: 0 0;
	}
	50.1% {
		transform: scale(1, 1);
		transform-origin: 0 100%;
	}
	100% {
		transform: scale(1, 0);
		transform-origin: 0 100%;
	}
}
.mainVisual .foo {
	overflow: hidden;
}
.mainVisual .foo li {
	width: 100%;
	height: 100svh;
}
.mainVisual .foo img,
.mainVisual .foo video {
	width: 100%;
	height: inherit;
	object-fit: cover;
}
@media (max-width: 1300px) {
	.circle-link {
		right: 0;
	}
}
@media (max-width: 1199px) {
	/* .mv-inner {
		max-width: 980px;
	} */
	.circle-link {
		bottom: 40px;
	}
}
@media (max-width: 767px) {
	.mv-inner h1 {
		margin-bottom: calc(4rem * 0.8);
		font-size: calc(4rem * 0.8);
	}
	.mv-inner span {
		font-size: calc(2.2rem * 0.8);
	}
	.circle-link {
		bottom: 32px;
	}
}
@media (max-width: 580px) {
	.circle-link {
		width: 100px;
		height: 100px;
	}
	.mv-inner span.circle-text {
		font-size: 13px;
	}
	.circle-btn {
		width: 32px;
		height: 32px;
	}
}
@media (max-width: 440px) {
	.mv-inner h1 {
		margin-bottom: calc(4rem * 0.7);
		font-size: calc(4rem * 0.7);
	}
	.mv-inner span {
		font-size: calc(2.2rem * 0.7);
	}
}

#main .information {
	padding: 4.2rem 0 8.2rem;
}
#main .information .innerBox {
	margin-bottom: 7.8rem;
}
#main .information .headLine01 {
	margin-right: 4.4rem;
	width: fit-content;
	text-align: left;
}
#main .information .headLine01 .jp {
	letter-spacing: 0.05em;
}
#main .information .comNewsList {
	margin-top: 2rem;
	width: 61.3rem;
}
#main .concept {
	padding-top: 11rem;
	color: #fff;
	background: url(../img/index/concept_photo01.jpg) no-repeat center center / cover;
	min-height: 80rem;
	display: flex;
	align-items: center;
}
#main .concept .headLine01 {
	margin: 0 auto 7rem;
	color: #fff;
}
#main .concept .headLine01 .jp {
	letter-spacing: 0;
}
#main .concept .text {
	margin-bottom: 24.5rem;
	text-align: center;
	font-size: 2.5rem;
	line-height: 1.8;
	letter-spacing: 0.089em;
}
#main .concept .comBtn a {
	color: #fff;
}
#main .concept .comBtn span,
#main .concept .comBtn span:before {
	background-color: #fff;
}
#main .about {
	padding: 6rem 0 7rem;
	background: #D4D0C6 url(../img/common/bg01.png) no-repeat center top / 128rem auto;
}
#main .about .lBox {
	margin-right: 8.8rem;
	width: 44rem;
}
#main .about .lBox .headLine01 {
	margin-bottom: 5rem;
	text-align: left;
}
#main .about .lBox .headLine01 .jp {
	letter-spacing: 0;
}
#main .about .textBox .text {
	margin-bottom: 3rem;
	color: #292929;
	font-size: 2.5rem;
	letter-spacing: 0.087em;
	line-height: 1.8;
}
#main .about .textBox .txt {
	line-height: 2.07;
}
#main .about .rBox {
	margin-top: 1.6rem;
}
#main .about .comPhotoList {
	margin-top: -5.5rem;
}
#main .about .comPhotoList li {
	margin-top: 5.5rem;
	box-shadow: 1rem 1rem 1rem 0 rgba(41, 41, 41, 0.1);
}
#main .about .textBox .txt:not(:last-of-type) {
	margin-bottom: 2.9rem;
}
#main .about .comPhotoList li:not(:nth-child(4n)) {
	margin-right: 0;
}
#main .about .comPhotoList li:not(:nth-child(2n)) {
	margin-right: 4.8rem;
}
#main .about .rBox {
	flex: 1;
}
#main .works {
	padding: 6.1rem 0 7.9rem;
}
#main .works .headLine01 {
	margin: 0 auto 7rem;
}
#main .works .comWorkList {
	margin-bottom: 8rem;
}
#main .interview {
	padding-top: 6.1rem;
}
#main .interview .content {
	padding-bottom: 8rem;
	border-bottom: 0.1rem solid #D4D4D4;
}
#main .interview .headLine01 {
	margin: 0 auto 7rem;
}
#main .area {
	padding: 6.3rem 0 8rem;
}
#main .area .mapBox {
	margin-bottom: 7.8rem;
}
#main .area .lBox {
	margin: 12rem 7.8rem 0 -0.2rem;
	width: 55.5rem;
	height: 65.3rem;
}
#main .area .rBox {
	flex: 1;
}
#main .area .headLine01 {
	margin-bottom: 6.2rem;
	text-align: left;
}
#main .area .mapList {
	letter-spacing: 0.1em;
}
#main .area .mapList > li {
	padding: 1.8rem 0 1.8rem 0.2rem;
	display: flex;
	justify-content: space-between;
	border-bottom: 0.2rem dotted #A9A9A9;
}
#main .area .mapList > li:first-child {
	border-top: 0.2rem dotted #A9A9A9;
}
#main .area .countryList {
	margin-top: -1rem;
	width: 23.5rem;
}
#main .area .countryList li {
	margin: 1rem 3.6rem 0 0;
	cursor: pointer;
}
#main .area .countryList li:nth-child(3n) {
	margin-right: 0;
}
.cls-1 {
	isolation: isolate;
}
.cls-2 {
	fill: none;
	stroke: #949494;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-width: .5px;
}
.cls-2, .cls-3, .cls-4 {
	fill-rule: evenodd;
}
.cls-3 {
	fill: #dfdcd4;
}
.cls-3, .cls-4 {
	mix-blend-mode: multiply;
	stroke: #fff;
	stroke-width: .7px;
}
path {
	fill: #dfdcd4;
	transition: all 0.3s;
}
path.hover {
	fill: #bfb8aa;
}
#main .blog {
	padding: 6.2rem 0 8rem;
	background-color: #DFDCD4;
}
#main .blog .headLine01 {
	margin: 0 auto 7rem;
}
#main .blog .comBtn span,
#main .ins .comBtn span,
#main .movie .comBtn span {
	background-color: #949494;
}
#main .blog .comBtn span::before,
#main .ins .comBtn span::before,
#main .movie .comBtn span::before {
	background-color: #949494;
}
#main .ins {
	padding: 8rem 0;
}
#main .ins h2 {
	margin-bottom: 4rem;
	padding: 0.5rem 0 0.5rem 5rem;
	font-size: 1.5rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	background: url(../img/common/icon12.png) no-repeat left center / 3.2rem;
}
#main .ins .insList {
	margin: -2.5rem 0 7.8rem;
}
#main .ins .insList li {
	margin: 2.5rem 2.5rem 0 0;
	width: 19.1rem;
}
#main .ins .insList a {
	display: block;
}
#main .ins .insList img {
	width: 100%;
	object-fit: cover;
}
#main .ins .insList li:nth-child(5n) {
	margin-right: 0;
}
#main .movie {
	padding: 7.9rem 0;
	background-color: #DFDCD4;
}
#main .movie h2 {
	margin-bottom: 3.8rem;
	padding: 0.5rem 0 0.5rem 5rem;
	font-size: 1.5rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	background: url(../img/common/icon13.png) no-repeat left center / 3.4rem;
}
#main .movie .movieList {
	margin-bottom: 7.8rem;
}
#main .movie .movieList li {
	margin-right: 2.6rem;
	width: 24.45rem;
}
#main .movie .movieList a {
	display: block;
}
#main .movie .movieList img {
	width: 100%;
	object-fit: cover;
}
#main .movie .movieList li:nth-child(4n) {
	margin-right: 0;
}
@media all and (min-width: 897px) {
	#main .area .countryList a:hover,
	#main .ins .insList a:hover,
	#main .movie .movieList a:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	.mainVisual .scroll {
		left: 1rem;
	}
	.mainVisual .foo img {
		object-position: center;
	}
	#main .information {
		padding: 4.2rem 0 5rem;
	}
	#main .information .innerBox {
		margin-bottom: 3.6rem;
		display: block;
	}
	#main .information .headLine01 {
		margin: 0 auto 3.3rem !important;
		text-align: center;
	}
	#main .information .comNewsList {
		width: auto;
	}
	#main .concept {
		padding: 0 0 1rem;
		min-height: 66.7rem;
		background-image: url(../img/index/concept_photo01_sp.jpg);
	}
	#main .concept .headLine01 {
		margin-bottom: 2.7rem !important;
	}
	#main .concept .text {
		margin-bottom: 38.2rem;
		font-size: 2.1rem;
	}
	#main .about {
		padding: 4.2rem 0 5rem;
		background-image: url(../img/index/about_bg_sp.png);
		background-size: 100% auto;
	}
	#main .about .content {
		display: block;
	}
	#main .about .lBox {
		margin: 0 0 4.2rem;
		width: auto;
	}
	#main .about .lBox .headLine01 {
		margin: 0 auto 2.8rem !important; 
		text-align: center;
	}
	#main .about .textBox .text {
		margin-bottom: 2.3rem;
		text-align: center;
		font-size: 2.1rem;
	}
	#main .about .textBox .txt {
		margin: 0 -0.1rem;
		text-align: center;
		font-size: 1.2rem;
		line-height: 2.16;
	}
	#main .about .textBox .txt:not(:last-of-type) {
		margin-bottom: 2.7rem;
	}
	#main .about .comPhotoList {
		margin-top: -2rem;
	}
	#main .about .comPhotoList li {
		margin-top: 2rem;
	}
	#main .about .comPhotoList li:not(:nth-child(2n)) {
		margin-right: 0;
	}
	#main .works {
		padding: 4.2rem 0 5rem;
	}
	#main .works .headLine01 {
		margin-bottom: 3.8rem !important;
	}
	#main .works .comWorkList {
		margin-bottom: 3.6rem;
	}
	#main .interview {
		padding-top: 4.2rem;
	}
	#main .interview .content {
		padding-bottom: 0;
		border: 0;
	}
	#main .interview .headLine01 {
		margin-bottom: 3.7rem !important;
	} 
	#main .area {
		padding: 5.8rem 0 5rem;
	}
	#main .area .mapBox {
		margin-bottom: 3.7rem;
		display: block;
	}
	#main .area .headLine01 {
		margin: 0 auto 3.8rem !important;
		text-align: center;
	}
	#main .area .mapList {
		font-size: 1.3rem;
	}
	#main .area .countryList {
		width: 20.4rem;
	}
	#main .area .countryList li {
		margin-right: 3.4rem;
	}
	#main .area .countryList .li01 {
		margin-right: 3rem;
	}
	#main .area .countryList .li02 {
		margin-right: -0.8rem !important;
	}
	#main .blog {
		padding: 4.1rem 0 4.9rem;
	}
	#main .blog .headLine01 {
		margin-bottom: 3.7rem !important;
	}
	#main .ins {
		padding: 4.6rem 0 5rem;
	}
	#main .ins h2 {
		margin-bottom: 3.6rem;
		padding: 0.5rem 0 0.8rem 4.3rem;
		font-size: 1.3rem;
		background-size: 2.7rem;
	}
	#main .ins .insList {
		margin: -1rem 0 3.8rem;
	}
	#main .ins .insList li {
		margin: 1rem 2.9% 0 0 !important;
		width: 31.4%;
	}
	#main .ins .insList li:nth-child(3n) {
		margin-right: 0 !important;
	}
	#main .movie {
		padding: 4.1rem 0 4.9rem;
	}
	#main .movie h2 {
		margin-bottom: 3.4rem;
		padding: 0.5rem 0 0.8rem 4.3rem;
		font-size: 1.3rem;
		background-size: 2.9rem;
	}
	#main .movie .slideBox {
		position: relative;
	}
	#main .movie .slideBox .prev,
	#main .movie .slideBox .next {
		width: 0.6rem;
		position: absolute;
		top: 50%;
		transform: translateY(-30%);
	}
	#main .movie .slideBox .prev {
		left: -1.2rem;
	}
	#main .movie .slideBox .next {
		right: -1.2rem;
	}
	#main .movie .movieList {
		margin-bottom: 3.4rem;
		display: block;
		overflow: hidden;
	}
	#main .movie .movieList .slick-list {
		margin: 0 -1rem;
	}
	#main .movie .movieList li {
		width: auto;
	}
	#main .movie .movieList .slick-slide {
		margin: 0 1rem;
	}
}