@charset "UTF-8";

/*==================================================================
	Development setting
===================================================================*/
.mv_movie {
	width: 100%;
}
.head_block {
	padding: 80px 0 80px;
}
.head_block .ttl_en {
	display: flex;
	align-items: center;
	gap:15px;
	font-size: 2rem;
	letter-spacing: 0.25em;
	margin-bottom: 30px;
}
.head_block .ttl_en:after {
	background-color: #231f20;
	content: "";
	flex: 1;
	height: 1px;
	width: auto;
}
.head_block .ttl_jp {
	font-size: 3.4875vw;
	letter-spacing: 0.25em;
	margin-bottom: 30px;
}
.head_block .txt_jp {
	font-size: 1.6rem;
	letter-spacing: 0.18em;
	line-height: 2;
}
@media only screen and (max-width: 767px) {
	.head_block { padding: 40px 0;}
	.head_block .ttl_en { font-size: 1.4rem;}
	.head_block .ttl_jp { font-size: 1.6rem; letter-spacing: 0.1em;}
	.head_block .txt_jp { font-size: 1.2rem; letter-spacing: 0.1em;}
}


/* common */
.eng {
	font-family: "latino-gothic-variable", sans-serif;
	font-variation-settings: "slnt" 1, "wdth" 67, "wght" 1;
}
.gothic {
	font-family: "小塚ゴシック Pro", "Kozuka Gothic Pro", sans-serif;
}
sup {
	font-size: 50%;
}
big {
	font-size: 120%;
}
small {
	font-size: 65%;
}
.c_red {
	color: #d4273d;
}
.c_whi {
	color: #fff;
}
.pos_rel {
	position: relative;
}
.pc48 {
	display: block;
}
.sp48 {
	display: none;
}
.sp2 {
	display: none;
}
@media only screen and (max-width: 767px) {
	.sp2 {
		display: block;
	}
}
@media only screen and (max-width: 480px) {
	.pc48 {
		display: none;
	}
	.sp48 {
		display: block;
	}
	.sp2 {
		display: none;
	}
}


/*---------------------------------
	topへ戻る
---------------------------------*/
.top_back {
	z-index: 6;
	position: fixed;
	bottom: 2rem;
	right: 2rem;
	opacity: 0.4;
	width: 50px;
	height: 40px;
	font-size: 1.0rem;
	color: #000;
	background-color: #ccc;
	display: flex;
	justify-content: center;
	padding: 5px 0;
	transition: all 0.3s ease;
}
@media screen and (max-width: 1024px) {
	.top_back {
		bottom: 10rem;
		right: 1rem;
	}
}
.top_back::after {
	content: "";
	width: 16px;
	height: 16px;
	border-bottom: 2px solid #000;
	border-right: 2px solid #000;
	background-color: transparent;
	bottom: 1px;
	right: 16px;
	position: absolute;
	transform: rotate(-135deg);
}


/* sec01 area */
.sec01 {
	width: 100%;
	display: flex;
	gap: 20px 2%;
	background: #000;
	height: 760px;
}
.sec01 .left {
	width: 48%;
	height: 100%;
}
.sec01 .left img{
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.sec01 .right {
	width: 48%;
	height: 100%;
	display: flex;
	gap: 2%;
	margin-right: 2%;
}
.sec01 .right .slide01 {
	width: 49%;
}
.sec01 .right .slide02 {
	width: 49%;
}
@media only screen and (max-width: 767px) {
	.sec01 {
		display: flex;
		flex-wrap: wrap;
		gap: 30px 4%;
		height: 100%;
	}
	.sec01 .left {
		width: 100%;
	}
	.sec01 .right {
		width: 100%;
	}
	.sec01 .right .slide01 {
		width: 46%;
		margin-left: 2%;
	}
	.sec01 .right .slide02 {
		width: 46%;
		margin-right: 2%;
	}
}


/* sec02 area */
.sec02 {
	width: 100%;
	background-color: #000;
	margin-top: -2px;
	padding-top: 100px;
	padding-bottom: 120px;
}
.sec02 .title01 {
	font-size: 2.0rem;
	line-height: 1.6;
	text-align: center;
	letter-spacing: 0.2em;
	color: #fff;
	margin: 0 auto 40px;
}
.sec02 .title02 {
	font-size: 3.6rem;
	line-height: 1.8;
	text-align: center;
	letter-spacing: 0.15em;
	color: #fff;
	margin: 0 auto 40px;
}
.sec02 .text {
	font-size: 1.6rem;
	line-height: 1.8;
	text-align: center;
	letter-spacing: 0.1em;
	color: #fff;
	margin: 0 auto 80px;
}
.sec02 .merit {
	width: 90%;
	display: flex;
	flex-wrap: wrap;
	gap: 30px 2%;
	margin: 0 auto;
}
.sec02 .merit p {
	width: 48.5%;
}
@media only screen and (max-width: 767px) {
	.sec02 {
		padding-top: 60px;
		padding-bottom: 60px;
	}
	.sec02 .title01 {
		font-size: 1.6rem;
		margin: 0 auto 25px;
	}
	.sec02 .title02 {
		font-size: 2.6rem;
		margin: 0 auto 25px;
	}
	.sec02 .text {
		font-size: 1.3rem;
		line-height: 1.6;
		margin: 0 auto 50px;
	}
	.sec02 .merit {
		width: 98%;
		gap: 20px 2%;
	}
}
@media only screen and (max-width: 480px) {
	.sec02 {
		padding-bottom: 30px;
	}
	.sec02 .title01 {
		font-size: 1.3rem;
		letter-spacing: 0.15em;
		margin: 0 auto 20px;
	}
	.sec02 .title02 {
		font-size: 2.0rem;
		letter-spacing: 0.1em;
		margin: 0 auto 20px;
	}
	.sec02 .text {
		font-size: 1.1rem;
		line-height: 1.5;
		margin: 0 auto 40px;
	}
	.sec02 .merit {
		width: 90%;
		gap: 15px 2%;
	}
	.sec02 .merit p {
		width: 100%;
	}
}


/* sec03 area */
.sec03 {
	width: 100%;
	background-color: #000;
	margin-top: -2px;
	padding-bottom: 80px;
}
.sec03 .title {
	width: 94%;
	text-align: center;
	margin: 0 auto 40px;
	padding-top: 40px;
}
.sec03 .title .t01 {
	width: 76%;
	max-width: 740px;
	margin: 0 auto 5px;
}
.sec03 .title .t02 {
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.2;
	text-align: center;
	letter-spacing: 0.05em;
	color: #fff;
	border-top: solid 1px #fff;
	margin: 2px auto 10px;
	padding-top: 15px;
}
.sec03 .title .t03 {
	width: 100%;
	font-size: 1.6rem;
	line-height: 1.2;
	text-align: center;
	letter-spacing: 0.05em;
	color: #fff;
	border-top: solid 1px #fff;
	margin: -13px auto 10px;
	padding-top: 15px;
}
@media only screen and (max-width: 767px) {
	.sec03 {
		padding-bottom: 40px;
	}
	.sec03 .title .t01 {
		width: 84%;
		margin: 0 auto 5px;
	}
	.sec03 .title .t02 ,
	.sec03 .title .t03 {
		font-size: 1.5rem;
	}
}
@media only screen and (max-width: 480px) {
	.sec03 {
		padding-bottom: 25px;
	}
	.sec03 .title {
		margin: 0 auto 30px;
		padding-top: 20px;
	}
	.sec03 .title .t01 {
		width: 94%;
		margin: 0 auto 2px;
	}
	.sec03 .title .t02 {
		font-size: 1.2rem;
		padding-top: 10px;
	}
	.sec03 .title .t03 {
		font-size: 1.2rem;
		margin: -8px auto 10px;
		padding-top: 10px;
	}
}

.sec03 .g_table {
	width: 94%;
	display: flex;
	justify-content:center;
	gap: 2%;
	margin: 0 auto 60px;
}
.sec03 .g_table li{
	display:flex;
	flex-direction:column;
	position: relative;
}
.sec03 .g_table .b01{
	width: 49%;
}
.sec03 .g_table .b02{
	width: 23.5%;
}
@media only screen and (max-width: 767px) {
	.sec03 .g_table {
		width: 94%;
		display: flex;
		flex-wrap: wrap;
		gap: 40px 4%;
		margin: 0 auto 40px;
	}
	.sec03 .g_table .b01{
		width: 100%;
	}
	.sec03 .g_table .b02{
		width: 48%;
	}
}

.sec03 .top{
	width: 100%;
	background: #404040;
	padding: 0;
}
.sec03 .top .txt1 {
	width: 100%;
	font-size: 1.3rem;
	color: #cfcfcf;
	text-align: center;
	background: #322f31;
	margin: 0 auto;
	padding: 3px;
}
.sec03 .top .txt2 {
	width: 100%;
	height: 5vw;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	margin: 0;
}
.sec03 .top .txt2 p {
	font-size: 1.8rem;
	line-height: 1.5;
	text-align: center;
	color: #fff;
	margin: 0;
	padding: 10px;
	box-sizing: border-box;
}
.sec03 .top .txt2 p span {
	border-bottom: 1px solid #fff;
	line-height: 1.1;
}
.sec03 .middle{
	display: flex;
	align-items: center;
	min-height: 160px;
}
.sec03 .arrow-line{
	position: relative;
	width: 1px;
	height: 90%;
	background: rgba(255,255,255,0.2);
	margin: 0 3% 0 5%;
	flex-shrink: 0;
}
/*
.sec03 .arrow-line{
	position:relative;
	width:1px;
	height:100%;
	background:#fff;
	margin:0 3% 0 5%;
	flex-shrink:0;
}
*/
.sec03 .arrow-line::before {
	content: "";
	position: absolute;
	left: 0;
	top: -40px;
	width: 100%;
	height: 40px;
	background: linear-gradient(
		to bottom,
		rgba(255,255,255,0),
		rgba(255,255,255,1),
		rgba(255,255,255,0)
	);
	animation: lineFlow 2s linear infinite;
}
@keyframes lineFlow {
	0% {
		top: -20px;
	}

	100% {
		top: calc(100% - 40px);
	}
}

.sec03 .arrow-line::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: 3px;
	width: 25px;
	height: 25px;
	border-bottom: 1px solid #fff;
	transform: translateX(-50%) rotate(45deg);
}
.sec03 .arrow-note{
	width:86%;
	font-size:1.5rem;
	font-weight:bold;
	line-height:1.6;
	text-align:center;
	color:#fff;
	display:flex;
	align-items:center;
	justify-content:center;
	background:#a40000;
	border-radius:999px;
	margin:0 auto;
	padding:10px;
}
.sec03 .bottom{
	width:100%;
	background:#b1aca5;
	display:flex;
	flex-direction:column;
	flex:1;
}
.sec03 .bottom .img1 {
	width: 95%;
	margin: 15px auto 20px;
}
.sec03 .bottom .img2{
	width: 90%;
	margin: 15px auto 20px;
}
.sec03 .bottom .txt1 {
	width:100%;
	font-size: 1.3rem;
	color: #cfcfcf;
	text-align: center;
	background: #51534a;
	margin: 0 auto;
	padding: 3px;
}
.sec03 .bottom .txt2{
	font-size: 2.0rem;
	line-height: 1.4;
	font-weight:bold;
	text-align: center;
	color: #111;
	padding-bottom: 15px;
}
.sec03 .bottom .txt2 span {
	text-decoration: underline;
}
.sec03 .bottom .txt3 {
	font-size: 1.3rem;
	line-height: 1.4;
	text-align: center;
	color: #111;
	margin: 0 auto 15px;
}
.sec03 .txt4 {
	position: absolute;
	font-size: 1.3rem;
	line-height: 1.4;
	color: #fff;
	right: 0;
	bottom: -1.5vw;
}
@media only screen and (max-width: 767px) {
	.sec03 .top .txt1 {
		font-size: 1.2rem;
	}
	.sec03 .top .txt2 {
		height: 10vw;
	}
	.sec03 .top .txt2 p {
		font-size: 1.5rem;
		line-height: 1.4;
	}
	.sec03 .middle{
		min-height: 130px;
	}
	.sec03 .arrow-note{
		font-size:1.3rem;
		line-height:1.5;
	}
	.sec03 .bottom .txt1 {
		font-size: 1.2rem;
	}
	.sec03 .bottom .txt2{
		font-size: 1.6rem;
	}
	.sec03 .bottom .txt3 {
		font-size: 1.1rem;
		margin: 0 auto 10px;
	}
	.sec03 .txt4 {
		font-size: 1.2rem;
		bottom: -3vw;
	}
}
@media only screen and (max-width: 480px) {
	.sec03 .top .txt1 {
		font-size: 1.1rem;
	}
	.sec03 .top .txt2 {
		height: 12vw;
	}
	.sec03 .top .txt2 p {
		font-size: 1.25rem;
	}
	.sec03 .middle{
		min-height: 120px;
	}
	.sec03 .arrow-line::after {
		width: 20px;
		height: 20px;
	}
	.sec03 .arrow-note{
		font-size:1.1rem;
	}
	.sec03 .bottom .img1 {
		margin: 7px auto 10px;
	}
	.sec03 .bottom .img2{
		margin: 8px auto 10px;
	}
	.sec03 .bottom .txt1 {
		font-size: 1.1rem;
	}
	.sec03 .bottom .txt2{
		font-size: 1.25rem;
		padding-bottom: 5px;
	}
	.sec03 .bottom .txt3 {
		font-size: 0.9rem;
		margin: 0 auto 10px;
	}
	.sec03 .txt4 {
		font-size: 1.0rem;
		bottom: -4.5vw;
	}
}


/* sec04 */
.sec04 {
	width: 100%;
	background-color: #c8c4bf;
	padding-bottom: 120px;
}
.sec04 .link01_area {
	width: 100%;
	background-color: #000;
	margin-top: -2px;
	padding-bottom: 100px;
}
.sec04 .link01_area p {
	text-align: center;
	width: 70%;
	max-widrth: 500px;
	margin: 0 auto;
}
.sec04 .link01_area p a:hover {
	opacity: 0.7;
}
.sec04 .sec_arrow {
	width: 15%;
	max-width: 120px;
	margin: -1px auto 20px;
}
.sec04 .link02_area {
	width: 90%;
	max-width: 1200px;
	display: flex;
	gap: 5%;
	margin: 0 auto;
	padding-top: 60px;
}
.sec04 .link02_area p {
	width: 47.5%;
}
.sec04 .link02_area p a:hover {
	opacity: 0.7;
}
@media only screen and (max-width: 767px) {
	.sec04 {
		padding-bottom: 80px;
	}
	.sec04 .link01_area {
		padding-bottom: 60px;
	}
	.sec04 .link02_area {
		padding-top: 40px;
	}
}
@media only screen and (max-width: 480px) {
	.sec04 {
		padding-bottom: 50px;
	}
	.sec04 .link01_area {
		padding-bottom: 40px;
	}
	.sec04 .link01_area p {
		width: 86%;
		margin: 0 auto;
	}
	.sec04 .link02_area {
		display: flex;
		flex-wrap: wrap;
		gap: 25px;
		padding-top: 30px;
	}
	.sec04 .link02_area p {
		width: 80%;
		margin: 0 10%;
	}
}



@media only screen and (max-width: 767px) {
	.mb100 { margin-bottom: 50px !important; }
	.mb80 { margin-bottom: 40px !important; }
	.mb60 { margin-bottom: 30px !important; }
	.mb50 { margin-bottom: 25px !important; }
	.mb40 { margin-bottom: 20px !important; }
	.mb30 { margin-bottom: 15px !important; }
	.mb20 { margin-bottom: 15px !important; }
	.mt20 { margin-top: 10px !important; }
}

/* SCROLL */
.drag-scroll {
	display: flex;
	gap: 20px;
	overflow-x: auto;
	padding: 0;

	/* スクロールバー非表示 */
	scrollbar-width: thin;
	/* Firefox */
}
.drag-scroll::-webkit-scrollbar {
	display: thin;
	/* Chrome / Safari */
}
.drag-scroll img {
	object-fit: cover;
}
.jr_img {
	width: 165%;
	max-inline-size: none;
}
.scroll-wrap{
	width:90%;
	max-width:1600px;
	height:400px;
	margin:0 auto;
	overflow-x:auto;
	overflow-y:hidden;
	background:#fff;
	position:relative;
	touch-action: pan-y; /* タッチで縦スクロールはページ、横は要素に任せる */
	
	/* スクロールバー非表示 */
	scrollbar-width: none;
	-ms-overflow-style: none;
	margin-left: auto;
	margin-right: auto;
}
.scroll-wrap::-webkit-scrollbar{ display:none; }


.fade_up {
	transform: translateY(50px);
	opacity: 0;
}
.fade_up.is-active {
	transition: 1s;
	transform: translateY(0);
	opacity: 1;
}
.slidein {
	opacity: 0;
}
.slidein.is-active {
	animation: slideIn 5s cubic-bezier(0.23, 1, 0.32, 1) 1 forwards;
}
@keyframes slideIn {
	0% {
		transform: translateX(180px);
		opacity: 0;
	}
	100% {
		transform: translateX(0);
	}
	40%,
	100% {
		opacity: 1;
	}
}
.slidein_left {
	opacity: 0;
}
.slidein_left.is-active {
	animation: slideIn_Left 5s cubic-bezier(0.23, 1, 0.32, 1) 1 forwards;
}
@keyframes slideIn_Left {
	0% {
		transform: translateX(-180px);
		opacity: 0;
	}
	100% {
		transform: translateX(0);
	}
	40%,
	100% {
		opacity: 1;
	}
}
.fade_in {
	opacity: 0;
}
.fade_in.is-active {
	animation: fade_in 3s ease-in-out 0.2s 1 normal forwards;
}
@keyframes fade_in {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}
.fadeUp {
	animation-name: fadeUpAnime;
	animation-duration: 4s;
	animation-fill-mode: forwards;
	opacity: 0;
}
@keyframes fadeUpAnime {
	from {
		opacity: 0;
		transform: translateY(30px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}
/* アニメーションスタートの遅延時間を決めるCSS*/
.delay-time02 {
	animation-delay: 2s;
}
.delay-time04 {
	animation-delay: 3s;
}
.delay-time05 {
	animation-delay: 5s;
}
