@charset "UTF-8";

/*ttl_page
----------------------------------------*/
.ttl_page::before {
	content: '';
	display: block;
	width: 70.6rem;
	height: 55.7rem;
	background: url(../../img/service/ttl_page_bg_01.png) no-repeat left top / 100% auto;
	position: absolute;
	top: 6.273rem;
	right: 0;
}
@media only screen and (max-width: 768px) {
	.ttl_page::before {
		width: 31.8rem;
		height: 25.1rem;
		top: 4.6rem;
	}
}

/*service_overview
----------------------------------------*/
.service_overview {
	margin: 12rem 0 15.8rem;
}
.service_overview_inner {
	max-width: 124rem;
	margin: 0 auto 12rem;
	display: flex;
	padding-bottom: 11.8rem;
	border-bottom: .1rem solid #000;
}
.service_overview h2 {
	width: 32.2rem;
	display: flex;
	transition-delay: .3s;
}
.service_overview h2 span {
	display: block;
	writing-mode: vertical-rl;
}
.service_overview h2 span:not(.en) {
	font-size: 3rem;
	letter-spacing: .15em;
	color: #898788;
	margin-left: -.7rem;
}
.service_overview h2 .en {
	color: #C7C8C8;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: .02rem;
	padding-top: 1.8rem;
}
.service_overview h2 .en::before {
	content: '';
	display: block;
	width: .9rem;
	height: .9rem;
	border-radius: 50%;
	background: #C7C8C8;
	position: absolute;
	top: 0;
	left: .8rem;
}
.service_overview_box {
	flex: 1;
	transition-delay: .5s;
}
.service_overview_box h3 {
	font-size: 3rem;
	margin-bottom: 3.3rem;
}
.service_overview_box p {
	font-size: 1.8rem;
	letter-spacing: -.01em;
	line-height: 2;
	font-weight: 500;
}
.service_overview_list {
	max-width: 124rem;
	margin: 0 auto;
}
.service_overview_list_item {
	display: flex;
	gap: 10.9rem;
}
.service_overview_list_item + .service_overview_list_item {
	margin-top: 7rem;
	padding-top: 6rem;
	border-top: .1rem solid #C7C8C8;
}
.service_overview_list_item figure {
	width: 53.3rem;
}
.service_overview_list_box {
	flex: 1;
	transition-delay: .2s;
}
.service_overview_list_category {
	font-size: 1.6rem;
	color: #898788;
	margin: -.2rem 0 3.8rem;
}
.service_overview_list_category span {
	display: block;
	color: #00AEC7;
	font-weight: 500;
	margin-bottom: .3rem;
}
.service_overview_list_box h3 {
	font-size: 3rem;
	line-height: 1.6;
	margin-bottom: 2.5rem;
}
.service_overview_list_txt {
	font-size: 1.5rem;
	line-height: 2.4;
}
@media only screen and (max-width: 768px) {
	.service_overview {
		margin: 10.5rem 0 8rem;
	}
	.service_overview_inner {
		margin: 0 2rem 7rem;
		display: block;
		padding-bottom: 0;
		border-bottom: 0;
	}
	.service_overview h2 {
		width: auto;
		margin-bottom: 4.7rem;
	}
	.service_overview h2 span:not(.en) {
		letter-spacing: 0;
	}
	.service_overview_box h3 {
		font-size: 2.6rem;
		margin: 0 0 2.2rem .2rem;
	}
	.service_overview_box p {
		letter-spacing: 0;
	}
	.service_overview_list_item {
		display: block;
	}
	.service_overview_list_item + .service_overview_list_item {
		margin-top: 5.3rem;
		padding-top: 0;
		border-top: 0;
	}
	.service_overview_list_item figure {
		width: auto;
	}
	.service_overview_list_box {
		padding: 3.4rem 2rem 0;
	}
	.service_overview_list_category {
		font-size: 1.4rem;
		margin: -.2rem 0 2.2rem;
	}
	.service_overview_list_category span {
		font-size: 1.6rem;
	}
	.service_overview_list_box h3 {
		font-size: 2.2rem;
		line-height: 1.5909;
		margin-bottom: 1.9rem;
	}
	.service_overview_list_txt {
		font-size: 1.4rem;
		line-height: 2;
	}
}

/*service_initiatives
----------------------------------------*/
.service_initiatives {
	padding: 10.6rem 0 11.4rem;
	margin-top: -100vh;
	background: #F3F3F3;
	z-index: 1;
}
.service_initiatives_inner {
	max-width: 124rem;
	margin: 0 auto;
}
.service_initiatives h2 {
	display: flex;
	margin-bottom: 7.5rem;
}
.service_initiatives h2 span {
	display: block;
	writing-mode: vertical-rl;
}
.service_initiatives h2 span:not(.en) {
	font-size: 3rem;
	line-height: 1.2;
	letter-spacing: .12em;
	color: #898788;
	margin-left: -.2rem;
}
.service_initiatives h2 .en {
	color: #C7C8C8;
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: .02rem;
	padding-top: 1.8rem;
	margin-left: 1.6rem;
}
.service_initiatives h2 .en::before {
	content: '';
	display: block;
	width: .9rem;
	height: .9rem;
	border-radius: 50%;
	background: #C7C8C8;
	position: absolute;
	top: 0;
	left: .8rem;
}
@media only screen and (max-width: 768px) {
	.service_initiatives {
		padding: 8rem 0 11.4rem;
	}
	.service_initiatives_inner {
		margin: 0 2rem;
	}
	.service_initiatives h2 {
		margin-bottom: 5.6rem;
	}
	.service_initiatives h2 span:not(.en) {
		margin-left: -.5rem;
	}
	.service_initiatives h2 .en {
		margin-left: .8rem;
	}
}

/*hotels_main
----------------------------------------*/
.hotels_main {
	position: sticky;
	top: 0;
	left: 0;
}
.hotels_wrap {
	background: #fff;
}