/*==================================================================
  Base setting
===================================================================*/
html {
	font-size: 62.5% !important;
	min-width: auto !important;
}
.pos_rel { position: relative;}
.pic_cap {
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 20;
	color: #000 !important;
	font-size: 10px;
	line-height: 1.2 !important;
	padding: 5px;
}
.pic_cap.l_side {
	right: auto;
	left: 0;
}
.pic_cap.bg {
	background: rgba(0, 0, 0, 0.5);
	color: #fff !important;
}
.pic_cap.w { color: #ffffff !important;}
.d_inline_block {
	display: inline-block;
}
.inner {
	margin: 0 auto;
	max-width: 1200px;
	padding: 0 15px;
}
.full { width: 100%;}
.sp { display: none;}
.pc { display: block;}
@media screen and (max-width: 767px) {
	.sp { display: block;}
	.pc { display: none;}
}
.passions { font-family: "Passions Conflict", cursive;}
.cormorant { font-family: "Cormorant Garamond", serif;}
.gradient01 {
	background: -o-linear-gradient(18deg,  #413424 0%,#bdac71 52%,#413424 100%);
	background: linear-gradient(18deg,  #413424 0%,#bdac71 52%,#413424 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
.gradient02 {
	background: -o-linear-gradient(315deg, #998c6d 0%, #efe7cb 54%, #998d6e 100%);
	background: linear-gradient(135deg, #998c6d 0%, #efe7cb 54%, #998d6e 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
/* fade in */
.fadein { opacity: 0; }
.fadein.on { animation: fadeInAnime ease-in-out 1.2s forwards; }

@keyframes fadeInAnime{
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

/* fade up */
.fadeup { opacity: 0; }
.fadeup.on { animation: fadeUpAnime ease-out 1.2s forwards; }
@keyframes fadeUpAnime{
  from {
    opacity: 0;
    transform: translateY(50px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/*==================================================================
  Contents setting
===================================================================*/
.main_visual {
	overflow: hidden;
	position: relative;
}
.mv_sliders .item .img {
	height: 100vh;
	position: relative;
}
.mv_sliders .item .img img {
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.mv_cont {
	color: #ffffff;
	position: absolute;
	top: 95px;
	left: 0;
	right: 0;
	z-index: 9;
	text-align: center;
	pointer-events: none;
}
.mv_cont img { max-width: 420px;}
@media screen and (max-width: 1024px) {
	.mv_cont { top: 60px;}
}
@media screen and (max-width: 767px) {
	.mv_cont { top: 45px;}
	.mv_cont img { width: 65%;}
}
#container {
	font-family: "Noto Serif JP", serif;
}
/* sec_value */
.c_gold { color: #fff697;}
.c_gold02 { color: #999584;}
.sec_head_box {
	text-align: center;
	margin-bottom: 130px;
}
.sec_head_box .ttl {
	font-size: 2rem;
	line-height: 1;
	letter-spacing: 0.1em;
}
.sec_head_box .ttl .en {
	font-size: 350%;
	margin-top: -15px;
}
.sec_head_box .ttl .lg {
	font-size: 170%;
	letter-spacing: 0.1em;
	display: block;
	margin-top: 35px;
	line-height: 1.5;
}
.sec_head_box .txt {
	display: block;
	font-size: 2.8rem;
	line-height: 1.9;
	letter-spacing: 0.1em;
	margin: 35px 0 0;
}
.sec_head_box .txt_sm {
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	line-height: 2.25;
	margin-top: 45px;	
}
@media screen and (max-width: 1024px) {
	.sec_head_box .txt { font-size: 2.4rem;}
	.sec_head_box .txt_sm { font-size: 1.4rem;}
}
@media screen and (max-width: 767px) {
	.sec_head_box { margin-bottom: 60px;}
	.sec_head_box .txt { font-size: 1.6rem;}
	.sec_head_box .ttl { font-size: 1.4rem;}
	.sec_head_box .ttl .lg {
		font-size: 1.7rem;
		margin-top: 5px;
	}
	.sec_head_box .txt_sm {
		font-size: 1.2rem;
		margin-top: 10px;
	}
}
.sec_value {
	padding: 130px 0 180px;
	position: relative;
	overflow: hidden;
	background-color: #665f55;
	color: #ffffff;
}
.sec_value::before {
	content: "";
	background: url(../img/value_bg.png) no-repeat top center/ 100% auto;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	display: block;
	left: 0;
	z-index: 1;
}
.sec_value .value_area {
	overflow: hidden;
	position: relative;
  z-index: 1;
}
.sec_value .value_area .img_plane {
	position: absolute;
    width: 59.2%;
    right: 0;
    top: 54.2%;
}
.sec_value .value_area .img_plane .pic_cap {
	bottom: 17%;
	right: 6%;
}
.sec_value .value_area + .value_area { padding-top: 175px;}
.sec_value .big_bg {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 40%;
}
.sec_value .value_rows { display: flex;}
.sec_value .value_rows .col_left {
	width: 195px;
	margin-right: 65px;
	position: relative;
}
.sec_value .value_rows .col_left::before,
.sec_value .value_rows .col_left::after {
	content: "";
	background-color: #fff;
	position: absolute;
	top: 180px;
}
.sec_value .value_rows .col_left::before {
	left: 0;
	width: 0;
	height: 1px;
  transition: all 0.3s linear;
}
.sec_value .value_rows .col_left.on::before { width: 100%;}
.sec_value .value_rows .col_left::after {
	width: 1px;
	height: 0;
	right: 0;
  transition: all 0.3s linear;
  transition-delay: 0.3s;
}
.sec_value .value_rows .col_left.on::after { height: 100%;}
.sec_value .value_rows .col_right {	flex: 1;}
.sec_value .box_ttl {
	font-size: 1.8rem;
	letter-spacing: 0.01em;
	text-transform: uppercase;
}
.sec_value .box_ttl small {
	font-size: 100%;
	letter-spacing: 0.1em;
	margin-top: 55px;
	display: block;
}
.sec_value .box_ttl.growth { margin-right: -130px;}
.sec_value .box_txt h4 {
	font-size: 2.2rem;
	letter-spacing: 0.01em;
	line-height: 2.2;
	margin-bottom: 15px;
}
.sec_value .box_txt h4 .large {
	font-size: 136%;
	line-height: 1;
}
.sec_value .box_txt h4 .large02 { font-size: 150%;}
.sec_value .box_txt h4 .small { font-size: 64%;}
.sec_value .box_txt p {
	font-size: 1.6rem;
	letter-spacing: 0.01em;
	line-height: 2.2;
}
.sec_value .box_txt.growth { padding-left: 100px;}
.sec_value .box_cap {
	font-size: 1rem;
	line-height: 2;
}
.sec_value .box_rank {
	margin: 0 auto;
	max-width: 600px;
	text-align: center;
}
.sec_value .sml_ttl {
	font-size: 1.2rem;
	letter-spacing: 0.05em;
	line-height: 1.5;
	margin-bottom: 10px;
}
.sec_value .img_left .img {
	width: calc(100% + (100vw - 1330px) / 2);
	margin-left: calc(-1 * (100vw - 1330px) / 2 + 8px);
}
.sec_value .img_right .img { width: calc(100% + (100vw - 895px) / 2);}
.sec_value .img_right .img .pic_cap { padding-right: 13px;}
.sec_value .img_growth .img { width: calc(150% + (100vw - 1330px) / 2);}
.sec_value .box + .box { margin-top: 8.5%;}
.sec_value .box .box_txt { 
	margin: 0 0 25px;
	position: relative;
	z-index: 1;
}
.sec_value .box { 
	max-width: 750px;
	position: relative;
}
.sec_value .value_block + .value_block { margin-top: 170px;}
.sec_value .value_block {
	position: relative;
	padding-right: 7%;
}
.sec_value .box_txt.mb15 h4,
.sec_value .box_txt.mb15 {
	margin-bottom: 15px !important;
}
.sec_value .block01 {
	display: grid;
	grid-template-columns: 75% 25%;
	gap: 60px;
}
.sec_value .block01 .img { width: calc(100% + (100vw - 985px) / 2);}
.sec_value .block01 .box_txt { margin-bottom: 55px;}
.sec_value .block01 .box_txt h4 { margin-bottom: 30px;}
.sec_value .block02 {
	display: grid;
	grid-template-columns: 15% auto;
	grid-template-rows: auto 1fr;
	column-gap: 60px;
	margin-top: 120px;
}
.sec_value .block02 .img { margin-left: calc(-1 * (100% + (100vw - 875px) / 2));}
.sec_value .block03 {
	display: grid;
	grid-template-columns: 47.9% auto;
	gap: 30px;
	width: 110%;
}
.sec_value .block04 {
	display: grid;
	grid-template-columns: 47.9% auto;
	gap: 30px;
	width: 93%;
}
.sec_value .img01 { width: 90%;}
.sec_value .block05 {
	display: grid;
	grid-template-columns: 62.5% auto;
	grid-template-rows: auto 1fr;
	column-gap: 30px;
}
.sec_value .block05.block05_01 { margin-top: 145px;}
.sec_value .block05 .img { width: calc(100% + (100vw - 865px) / 2);}
.sec_value .block06 {
	display: grid;
	grid-template-columns: 31% auto;
	gap: 60px;
	align-items: center;
}
.sec_value .block06 .img { margin-left: calc(-1 * (100% + (100vw - 1070px) / 2));}
.sec_value .block06 .box_txt { margin: -45px -40px 0 0 ;}
.sec_value .block07 {
	display: grid;
	grid-template-columns: 27% 67%;
	grid-template-rows: auto 1fr;
	column-gap: 30px;
	margin-top: 140px;
}
.sec_value .block07 .img { margin-left: calc(-1 * (100% + (100vw - 1055px) / 2));}

@media screen and (min-width: 768px) {
	.sec_value .value_rows .col_left.line01::after {
		height: 60%;
	}
	.sec_value .block02 > .item:nth-child(2) {
		grid-row: 1/3;
		grid-column: 1/2;
	}
	.sec_value .block05 .item:nth-child(2) {
		grid-row: 1/3;
		grid-column: 2/3;
	}
	.sec_value .block07 .item:nth-child(2) {
		grid-row: 1/3;
		grid-column: 1/2;
	}
	.sec_value .box_txt h4.mb40 { margin-bottom: 40px;}
	.sec_value .block07 .box_txt { margin-right: -40px;}
}
@media screen and (max-width: 1200px) {
   	.sec_value { padding: 100px 0 100px;}
	.sec_value .box {
		max-width: 100%;
		padding-left: 0;
	}
	.sec_value .img_growth .img { width: 45vw;}
	.sec_value .value_rows .col_left::before,
	.sec_value .value_rows .col_left::after {
		top: 135px;
	}
	.sec_value .value_rows .col_left {
		margin-right: 30px;
		position: relative;
	}
	.sec_value .box_txt h4 { font-size: 2rem;}
	.sec_value .box_txt p {
		font-size: 1.4rem;
		letter-spacing: 0;
	}
	.sec_value .value_rows .col_left { width: 150px;}
	.sec_value .box_ttl { font-size: 1.6rem;}
	.sec_value .box_ttl small { margin-top: 40px;}
	.sec_value .box_ttl.growth { margin-right: -100px;}
	.sec_value .box_txt.growth { padding-left: 100px;}
	.sec_value .block01 {
		grid-template-columns: 60% auto;
		gap: 30px;
	}
	.sec_value .block01 .img {
		width: calc(100% + 15px);
		margin-right: -15px;
	}
	.sec_value .block01 .box_txt h4 { margin-bottom: 15px;}
	.sec_value .block01 .box_txt { margin-bottom: 30px;}
	.sec_value .block02 {
		grid-template-columns: 18% auto;
		column-gap: 30px;
	}
	.sec_value .block02 .img { margin-left: -195px;}
	.sec_value .block03 {
    	width: 100%;
		grid-template-columns: 48.9% 1fr;
    	gap: 3%;
	}
	.sec_value .block04 {
    	gap: 3%;
		width: 100%;
		grid-template-columns: 48.5% auto;
	}
	.sec_value .value_block { padding: 0;}
	.sec_value .value_area + .value_area { padding-top: 70px;}
  	.sec_value .value_area .img_plane .pic_cap { right: 0;}
	.sec_value .block05 {
		grid-template-columns: 52% auto;
		column-gap: 30px;
	}
	.sec_value .block05 .img {
		width: calc(100% + 15px);
		margin-right: -15px;
	}
	.sec_value .block05 .box_txt h4 { margin-bottom: 15px;}
	.sec_value .block05 .box_txt { margin-bottom: 30px;}
	.sec_value .block05.block05_01 { margin-top: 120px;}
	.sec_value .block06 {
		grid-template-columns: 18% 54.5%;
		column-gap: 30px;
		align-items: initial;
	}
	.sec_value .block06 .box_txt { margin: 0 -40px 0 0;}
	.sec_value .block06 .img { margin-left: -195px;}
	.sec_value .block07 { grid-template-columns: 37% 55%;}
	.sec_value .block07 .img { margin-left: -195px;}
	.sec_value .value_area .img_plane { top: 57%;}
	.sec_value .value_area .img_plane .pic_cap { bottom: 50%;}
}

@media screen and (max-width: 767px) {
	.sec_value { padding: 60px 0;}
	.sec_value .box_ttl {
		font-size: 1.4rem;
		text-align: center;
		margin-bottom: 40px;
	}
	.sec_value .box_ttl.growth { margin-right: 0;}
	.sec_value .box_ttl small {	margin-top: 30px;}
	.sec_value .box_ttl .img {
		border-bottom: 1px solid #ffffff;
		padding-bottom: 45px;
	}
	.sec_value .box_ttl img { width: 100px;}
	.sec_value .box_ttl.growth img { width: 170px;}
	.sec_value .box_txt h4 { font-size: 1.7rem;}
	.sec_value .box_txt p {
		font-size: 1.3rem;
		line-height: 2;
	}
	.sec_value .box + .box { margin-top: 30px;}
	.sec_value .box .box_txt { margin: 0 0 20px;}
	.sec_value .box_txt.growth { padding-left: 0;}
	.sec_value .value_rows { display: block;}
	.sec_value .value_rows .col_left { width: 100%;}
	.sec_value .value_rows .col_left::before,
	.sec_value .value_rows .col_left::after { content: none;}
	.sec_value .block07,
	.sec_value .block06,
	.sec_value .block05,
	.sec_value .block04,
	.sec_value .block03,
	.sec_value .block02,
	.sec_value .block01 { 
		grid-template-columns: 1fr;
		gap: 30px;
	}
	.sec_value .block02 .img,
	.sec_value .block01 .img {
		width: 100%;
		margin: 0;
	}
	.sec_value .block02 { margin-top: 0;}
	.sec_value .value_area .img_plane {
		width: 78.2%;
		right: -28px;
		top: 0;
		max-width: 295px;
	}
	.sec_value .value_area .img_plane .pic_cap {
		bottom: 34%;
		right: 10%;
	}
	.sec_value .img01 { width: 100%;}
	.sec_value .block07,
	.sec_value .block06,
	.sec_value .block05 {
		gap: 20px;
	}
	.sec_value .block07 .img,
	.sec_value .block06 .img,
	.sec_value .block05 .img {
		width: 100%;
		margin: 0;
	}
	.sec_value .block05.block05_01,
	.sec_value .block07 { margin-top: 0;}
	.sec_value .block02 .box_txt,
	.sec_value .block05 .box_txt,
	.sec_value .block07 .box_txt,
	.sec_value .block06 .box_txt { margin: 0;}
	.sec_value .block06 { margin-top: -37%;}
	.sec_value .block06 .left_sp { margin-left: -15px;}
	.sec_value .block06 .item:nth-child(2) { margin-top: -30%;}
}
/* sec_location */
.sec_location {
	background-color: #f6f5eb;
	color: #3f3729;
}
.sec_location::before { content: none;}
.sec_location .value_rows .col_left::before, 
.sec_location .value_rows .col_left::after { background-color: #3f3729;}
@media screen and (max-width: 767px) {
	.sec_location::before { content: "";}
    .sec_location .box_ttl .img { border-bottom: 1px solid #3f3729;}
	.sec_location .box_txt p { font-size: 1.2rem;}
}
.sec_core {
	background: url(../img/core_bg.jpg) no-repeat center center/cover;
	padding: 100px 0 90px;
}
.sec_core .sec_head_box { margin-bottom: 35px;}
.sec_core .img_map {
	max-width: 1100px;
	margin: auto;
}
.core_block {
	max-width: 770px;
	margin: auto;
}
.core_block .topic {
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	color: #3f3729;
	margin-bottom: 10px;
}
.core_block .core_list {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 15px;
}
.core_block .core_list .ttl {
	font-size: 1.7rem;
	line-height: 1.6;
	color: #fff;
	background-color: rgba(87, 79, 49, 0.85);
	font-weight: 500;
	padding: 0 10px;
	margin-bottom: 5px;
}
.core_block .core_list .txt {
	font-size: 1.4rem;
	color: #231815;
	line-height: 1.7;
}
.core_block .note {
	font-size: 1rem;
	text-align: right;
	margin-top: -5px;
}
@media screen and (min-width: 768px) {
	.core_block .core_list .item:nth-child(2),
	.core_block .core_list .item:nth-child(1) { grid-row: 1/3;}
}
@media screen and (max-width: 767px) {
	.sec_core { padding: 60px 0;}
	.sec_core .img_map { margin: 0 auto 20px;}
	.sec_core .sec_head_box { margin-bottom: 20px;}
	.core_block .note { margin-top: -40px;}
	.core_block .topic {
    	font-size: 1.3rem;
		margin-bottom: 5px;
	}
	.core_block .core_list {
		gap: 10px;
		grid-template-columns: 1fr 1fr;
	}
	.core_block .core_list .ttl { font-size: 1.2rem;}
	.core_block .core_list .txt { font-size: 1rem;}
}
/*==================================================================
  contentSpecial
===================================================================*/
.contentSpecial {
	color: #595757;
	position: static;
	/*font-family: "Yu Mincho";*/
  font-family: 'Noto Serif JP';
	text-align: left;
}
.cont_common {
	position: relative;
	z-index: 2;
	padding: 140px 0;
}
.contentSpecial .baseHolder {
	padding: 0 15px;
	max-width: 1060px;
}
#contMatching li .section {
	border-bottom: solid 1px #d9d9d9;
	padding: 20px 0 24px;
}
#contMatching h2 {
	font-size: 2.8rem;
	letter-spacing: 0.02em;
	line-height: 1.8;
	color: #000000;
	text-align: center;
	margin-bottom: 45px;
}
#contMatching h2 .ttl {
  display: flex;
  align-items: center;
  justify-content: center;
}
#contMatching h2 .lg {
	font-size: 172%;
	color: rgba(63, 55, 41, 0.7);
}
#contMatching h2 .sm { font-size: 86%;}
@media screen and (max-width: 1200px) {
	.cont_common { padding: 100px 0;}
}
@media screen and (max-width: 767px) {
	.cont_common { padding: 60px 0;}
	#contMatching h2 {
		font-size: 2rem;
		line-height: 1.6;
		margin-bottom: 10px;
	}
}
/* result_introduce */
.result_inner {
	margin: 0 auto;
	max-width: 920px;
	padding-left: 15px;
	padding-right: 15px;
}
.result_introduce {
	overflow: hidden;
	background-color: #f5f5f7;
	position: relative;
	padding: 140px 0 120px;
}
.result_introduce .title-vision {
	max-width: 430px;
	margin: 0 auto 95px;
}
.result_introduce .intro_ttl {
	text-align: center;
	font-size: 2rem;
	color: #9c8954;
	margin-bottom: 60px;
}
.result_introduce .intro_inner {
	display: flex;
	flex-direction: row-reverse;
}
.result_introduce .intro_inner .item1 {
	width: 22%;
	position: relative;
}
.result_introduce .intro_cap {
	position: absolute;
	right: 0;
}
.result_introduce .intro_cap span { color: #9c8954;}
.result_introduce .intro_inner .item2 { flex: 1;}
.result_introduce .intro_read {
	font-size: 1.5rem;
	line-height: 2.6;
	letter-spacing: 3px;
	text-align: left;
	margin-top: 15px;
	letter-spacing: 0.02em;
}
@media screen and (max-width: 767px) {
	.result_introduce { padding: 60px 0;}
	.result_introduce .title-vision {
		margin-bottom: 60px;
		max-width: 212px;
		margin: 0 auto 35px;
	}
	.result_introduce .intro_ttl {
		font-size: 1.7rem;
		line-height: 1.7;
		margin-bottom: 100px;
	}
	.result_introduce .intro_inner {
		display: block;
		position: relative;
	}
	.result_introduce .intro_inner .item1,
	.result_introduce .intro_inner .item2 {
		width: 100%;
	}
	.result_introduce .intro_inner .intro_cap {
		line-height: 2;
		font-size: 1.6rem;
		letter-spacing: 0.1em;
		width: 100%;
		position: static;
		text-align: left;
		margin-bottom: 20px;
	}
	.result_introduce .intro_read {
		font-size: 1.2rem;
		line-height: 2.1;
		letter-spacing: 0.08em;
	}
}

/*--- result_award ---*/
.result_award { margin: 0 0 150px;}
.result_award .border_box {
	padding: 8% 6% 6%;
	border: 1px solid #9c8954;
}
.result_award .txt_area {
	text-align: center;
	color: #9c8954;
	font-size: 2.8rem;
	line-height: 1.6;
	letter-spacing: 0.1em;
	margin-bottom: 65px;
}
.result_award .logo_gd2024 {
	max-width: 290px;
	margin: 0 auto 35px;
}
.result_award .txt_area > span {
	border-bottom: 1px solid #595757;
	display: inline-block;
	padding-bottom: 35px;
}
.result_award .award_ttl {
	font-size: 1.7rem;
	margin-bottom: 10px;
}
.result_award .award_ttl .c_red { color: #7a1a33;}
.result_award .award_ttl .lg { font-size: 177%;}
.result_award .award_ttl img { max-width: 220px;}
.result_award .list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 27px;
}
.result_award .list.col3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}
.result_award .list + .list { margin-top: 100px;}
.result_award .list.col3 .award_ttl {
	font-size: 1.4rem;
	margin-bottom: 5px;
}
@media only screen and (max-width: 1024px) {
	.result_award { margin: 0 0 100px;}
	.result_award .border_box { padding: 40px 15px 30px;}
	.result_award .txt_area {
		font-size: 2.4rem;
		letter-spacing: 0.01em;
	}
	.result_award .txt_area > span { padding-bottom: 25px;}
	.result_award .award_ttl { font-size: 1.4rem;}
	.result_award .list.col3 .award_ttl { font-size: 1.1rem;}
	.result_award .list + .list { margin-top: 60px;}
}
@media only screen and (max-width: 767px) {
	.result_award { margin-bottom: 50px;}
	.result_award .txt_area {
		font-size: 1.9rem;
		margin-bottom: 35px;
	}
	.result_award .txt_area > span { padding-bottom: 35px;}
	.result_award .list.col3 .award_ttl,
	.result_award .award_ttl { font-size: 1.2rem;}
	.result_award .award_ttl .lg { font-size: 1.8rem;}
	.result_award .list.col3,
	.result_award .list {
		grid-template-columns: repeat(1, 1fr);
		gap: 20px;
	}
	.result_award .list.col3 { margin-top: 20px;}
	.result_award .logo_gd2024 {
		width: 60%;
		margin: 0 auto 20px;
	}
}

/*--- result_achieve ---*/
.result_achieve { padding: 180px 0 100px;}
.result_achieve div { line-height: 0;}
.result_achieve .caption {
	position: absolute;
	bottom: 0;
	right: 0;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	font-size: 12px;
	line-height: 1.2;
	padding: 5px;
	z-index: 1;
}
.result_achieve .image { position: relative;}
@media only screen and (max-width: 1024px) {
	.result_achieve { padding: 120px 0 100px;}
}
@media only screen and (max-width: 767px) {
	.result_achieve { padding: 40px 0 55px;}
}

/* map_area */
.result_achieve .map_area + .map_area { margin-top: 60px;}
.result_achieve .map_area .ttl {
	font-size: 3.2rem;
	text-align: center;
	line-height: 1.5;
	color: #9c8954;
	text-align: center;
}
.result_achieve .map_area .ttl span {	font-size: 1.8rem;}
.result_achieve .map_area .img01 {
	width: 66%;
	height: auto;
	margin: 0 0 0 auto;
}
.result_achieve .map_area .txt_area {	overflow: hidden;}
.result_achieve .map_area .txt_area .ttl {
	font-size: 2.8rem;
	color: #9c8954;
}
.result_achieve .map_area .txt_area .area_read {
	text-align: center;
	font-size: 1.6rem;
	line-height: 2.5;
	letter-spacing: 0.05em;
	margin: 30px auto 0;
}
@media only screen and (max-width: 767px) {
	.result_achieve .map_area + .map_area { margin-top: 20px;}
	.result_achieve .map_area .img01 {
		width: 100%;
		padding-bottom: 30px;
	}
	.result_achieve .map_area .txt_area .area_read {
		text-align: center;
		font-size: 1.2rem;
		line-height: 2.25;
	}
	.result_achieve .map_area .ttl { font-size: 2.5rem;}
	.result_achieve .map_area .txt_area .ttl { font-size: 2.2rem;}
}

/* image_area */
.result_achieve .map_area .map_cont { position: relative;}
.result_achieve .map_area .map_cont .ttl {
	position: absolute;
	width: 100%;
	top: 3px;
	overflow: hidden;
}
.result_achieve .image_area {
	margin-top: -40px;
	margin-bottom: 80px;
	padding-bottom: 120px;
}
.result_achieve .image_area .list { display: flex;}
.result_achieve .image_area .list li {
	width: auto;
	margin-right: 20px;
}
.result_achieve .image_area .list li .image { margin-bottom: 18px;}
.result_achieve .image_area .list li:last-child { margin-right: 0;}
.result_achieve .supply_block {
	position: absolute;
	left: 0%;
	top: 5%;
	width: 30%;
}
.result_achieve .supply_block .icon {
	text-align: center;
	margin: 0 auto 40px;
	display: block;
}
.result_achieve .supply_block .icon img { width: 58%;}
.result_achieve .supply_block .txt {
	font-size: 2rem;
	line-height: 1.4;
	letter-spacing: 0.1em;
	color: #231815;
	text-align: center;
}
.result_achieve .supply_block .c_gold {
	color: #9c8954;
	display: block;
	font-size: 170%;
	margin-top: 15px;
}

@media only screen and (max-width: 1024px) {
	.result_achieve .supply_block .txt { font-size: 1.6rem;}
}
@media only screen and (max-width: 767px) {
	.result_achieve .supply_block {
		position: static;
		width: auto;
		margin-bottom: 30px;
	}
	.result_achieve .supply_block .icon {
		max-width: 240px;
		margin: 0 auto 20px;
	}
	.result_achieve .supply_block .c_gold { margin-top: 10px;}
	.result_achieve .supply_block .txt {
		font-size: 1.3rem;
		letter-spacing: 0.1em;
	}
	.result_achieve .map_area .map_cont .ttl {
		position: static;
		margin-bottom: 10px;
	}
}

/* sec_salon */
.sec_salon {
	background-color: rgba(230, 227, 216, 0.6);
	padding: 130px 0 125px;
}
.salon_head {
	text-align: center;
	margin-bottom: 45px;
}
.salon_head .ttl {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	line-height: 1.7;
	margin-bottom: 20px;
}
.salon_head .ttl span {
	display: block;
}
.salon_head .ttl img {
	max-width: 495px;
	margin: 0 auto;
}
.salon_head .txt {
	font-size: 1.4rem;
	letter-spacing: 0.1em;
	line-height: 1.7;
}
.salon_block {
	display: grid;
	grid-template-columns: 36.5% auto;
	gap: 25px;
}
.salon_block {
	display: flex;
	max-width: 500px;
	justify-content: center;
	margin: auto;
}
.salon_block .txt {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	margin-top: 10px;
}
.salon_block .movie video { width: 100%;}
@media only screen and (max-width: 1024px) {
	.salon_block .txt {
		font-size: 1.4rem;
		letter-spacing: 0;
	}
}
@media only screen and (max-width: 767px) {
	.sec_salon { padding: 60px 0;}
	.salon_head .ttl img { max-width: 245px;}
	.salon_head .txt {
		font-size: 1.2rem;
		letter-spacing: 0.01em;
	}
	.salon_block {
		grid-template-columns: 1fr;
		gap: 30px;
	}
}
/* sec_remote */
.sec_remote { padding: 160px 0 100px;}
.sec_remote .ttl {
	font-size: 2.3rem;
	letter-spacing: 0.1em;
	line-height: 1.5;
	text-align: center;
	margin-bottom: 25px;
}
.sec_remote .ttl .sm { font-size: 74%;}
.sec_remote .ttl .lg { font-size: 140%;}
.sec_remote .bnr {
	max-width: 970px;
	margin: auto;
}
.sec_remote .bnr a { transition: all .3s;}
.sec_remote .bnr a:hover { opacity: .7;}
@media only screen and (max-width: 1024px) {
	.sec_remote { padding: 100px 0 100px;}
	.sec_remote .ttl {
		font-size: 2rem;
		letter-spacing: 0;
	}
}
@media only screen and (max-width: 767px) {
	.sec_remote { padding: 60px 0 0;}
	.sec_remote .ttl {
		font-size: 1.6rem;
		margin-bottom: 20px;
	}
}

/* Swipe icon */
.swipe_scroll{position: relative;}
.swipe_icon {display: none;}

@media only screen and (max-width: 767px) {
	.swipe_scroll_center,
	.swipe_scroll {
		overflow-x: auto;
		padding-bottom: 15px;
	}
	.swipe_scroll img {
		width: 768px;
		max-width: inherit;
	}
	.swipe_scroll_center img {
		width: 660px;
        max-width: inherit;
	}
	.swipe_icon {
		position: absolute;
		top: 50%;
		left: 50%;
		width: 70px;
		height: 70px;
		display: block;
		margin: -35px;
		animation:horizontal 1s ease-in-out infinite alternate;
		z-index: 10;
	}
	.swipe_icon img {
		max-width: 100%!important;
		width: 70px!important;
	}
	@keyframes horizontal {
		0% { transform:translate(-20%,-20%); }
		100% { transform:translate(30%,-20%); }
	}
}
/* top_btn  */
@media screen and (max-width: 767px) {
	.top_btn {
        z-index: 900!important;
    }
}
/* line gradient */
.line-gradient {
	background: rgba(163,139,57,1);
	height: 10px;
	width: 100%;
	overflow: hidden;
	position: absolute;
	top: 0;
}
.line-gradient > span {
	background: rgba(163,139,57,1);
	background: -moz-linear-gradient(left, rgba(163,139,57,1) 0%, rgba(224,216,188,1) 50%, rgba(163,139,57,1) 100%);
	background: -webkit-linear-gradient(left, rgba(163,139,57,1) 0%,rgba(224,216,188,1) 50%,rgba(163,139,57,1) 100%);
	background: linear-gradient(to right, rgba(163,139,57,1) 0%,rgba(224,216,188,1) 50%,rgba(163,139,57,1) 100%);
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 33.33%;
	-webkit-animation: gradient 5s infinite linear;
	-moz-animation: gradient 5s infinite linear;
	animation: gradientBg 5s infinite linear;
	text-indent: -999em;
}
@keyframes gradientBg {
	0% {
		left: 0%;
	}
	50% {
		left: 100%;
	}
	100% {
		left: 0%;
	}
}
@media only screen and (max-width: 767px) {
	.line-gradient {
		height: 3px;
	}
}
/* sec_residence */
.sec_residence {
	position: relative;
	padding: 105px 0 85px;
}
.sec_residence::before {
	content: "";
	background: url(../img/residence_bg.jpg) no-repeat top center/100% auto;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
}
.sec_residence .inner {
	max-width: 100%;
	padding: 0 4.4%;
}
.sec_residence .sec_head_box { margin-bottom: 50px;}
.sec_residence .sec_head_box .ttl .en { font-size: 3rem;}
.residence_gallery {
	display: grid;
	grid-template-columns: 30% 19.4% 11.9% auto;
	gap: 10px;
}
.residence_gallery .item {
	overflow: hidden;
	position: relative;
}
.residence_gallery .item .pic_cap {
	z-index: 0;
	letter-spacing: 0;
}
.residence_gallery .item:not(:nth-child(4)):before {
	background: -o-linear-gradient(35deg,  rgba(65,52,36,0.8) 0%,rgba(217,199,130,0.8) 34%,rgba(65,52,36,0.8) 100%);
	background: linear-gradient(35deg,  rgba(65,52,36,0.8) 0%,rgba(217,199,130,0.8) 34%,rgba(65,52,36,0.8) 100%);
	content: "";
	display: block;
	height: 0;
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	-webkit-transition: all 0.6s ease;
	transition: all 0.6s ease;
	opacity: 0;
	z-index: 1;
}
.residence_gallery .item:hover:before {
	height: 100%;
	opacity: 1;
}
.residence_gallery .item .pos_rel { height: 100%;}
.residence_gallery .item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.residence_gallery .item .copy {
	color: #FFF;
	display: block;
	position: absolute;
	left: 0;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 100%;
	text-align: center;
	z-index: 2;
}
.residence_gallery .item .copy span {
	display: block;
	-webkit-transition: all 0.6s ease;
	transition: all 0.6s ease 0.3s;
	opacity: 0;
}
.residence_gallery .item .copy span:first-child {
	font-family: "Noto Serif JP", serif;
	font-size: 2.8rem;
	line-height: 1.3;
	letter-spacing: 0.1em;
	margin-bottom: 20px;
	-webkit-transform: translate3d(0%, -100%, 0);
	transform: translate3d(0%, -100%, 0);
}
.residence_gallery .item .copy span:nth-child(2) {
	font-size: 1.7rem;
	line-height: 1.5;
	font-weight: 500;
	letter-spacing: 0.05em;
	font-family: "Cormorant Garamond", serif;
}
.residence_gallery .item:hover .copy span {
	-webkit-transform: translate3d(0%, 0%, 0);
	transform: translate3d(0%, 0%, 0);
	opacity: 1;
}
.residence_gallery .item a {
	display: block;
	height: 100%;
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
}
.residence_gallery .item a + figcaption { display: none;}
@media screen and (min-width: 768px) {
	.residence_gallery .item:nth-child(1) {
		grid-row: 1/1;
		grid-column: 1/2;
	}
	.residence_gallery .item:nth-child(2) {
		grid-row: 1/1;
		grid-column: 2/3;
	}
	.residence_gallery .item:nth-child(5) {
		grid-row: 1/3;
		grid-column: 3/5;
	}
	.residence_gallery .item:nth-child(3) {
		grid-row: 2/4;
		grid-column: 1/2;
	}
	.residence_gallery .item:nth-child(4) {
		grid-row: 2/2;
		grid-column: 2/3;
	}
	.residence_gallery .item:nth-child(6) {
		grid-row: 3/4;
		grid-column: 2/4;
	}
	.residence_gallery .item:nth-child(7) {
		grid-row: 3/4;
		grid-column: 4/5;
	}
}
@media screen and (max-width: 1200px) {
	.residence_gallery .item .copy span:first-child {
		font-size: 2rem;
		margin-bottom: 10px;
	}
	.residence_gallery .item .copy span:nth-child(2) { font-size: 1.4rem;}
}
@media screen and (max-width: 767px) {
	.sec_residence { padding: 50px 0 60px;}
	.sec_residence .inner { padding: 0 15px;}
	.sec_residence .sec_head_box { margin-bottom: 25px;}
	.sec_residence .sec_head_box .ttl .en {
		font-size: 2.6rem;
	}
	.residence_gallery {
		grid-template-columns: 49% 9.5% auto;
		gap: 5px;
	}
	.residence_gallery .item:nth-child(1) {
		grid-row: 1/1;
		grid-column: 1/3;
	}
	.residence_gallery .item:nth-child(2) {
		grid-row: 1/1;
		grid-column: 3/4;
	}
	.residence_gallery .item:nth-child(5) {
		grid-row: 3/4;
		grid-column: 3/4;
	}
	.residence_gallery .item:nth-child(3) {
		grid-row: 2/4;
		grid-column: 1/3;
	}
	.residence_gallery .item:nth-child(4) {
		grid-row: 2/3;
		grid-column: 3/4;
	}
	.residence_gallery .item:nth-child(6) {
		grid-row: 4/5;
		grid-column: 1/2;
	}
	.residence_gallery .item:nth-child(7) {
		grid-row: 4/5;
		grid-column: 2/4;
	}
	.residence_gallery .item .copy,
	.residence_gallery .item:before {
		display: none!important;
	}
}
.mfp-wrap,
.mfp-bg { min-width: 1000px;}
.mfp-image-holder .mfp-content { max-width: 60%!important;}
.mfp-image-holder .mfp-figure { position: relative;}
.mfp-image-holder .mfp-figure:after { display: none;}
.mfp-image-holder .mfp-figure img.mfp-img { padding: 0;}
.mfp-image-holder .mfp-close,
.mfp-image-holder .mfp-close:focus,
.mfp-image-holder .mfp-close:active {
	background: url(../img/close.svg) no-repeat 0 0!important;
	background-size: cover!important;
	cursor: pointer!important;
	height: 35px!important;
	width: 35px!important;
	font-size: 0;
	position: absolute!important;
	right: 0!important;
	top: -45px!important;
	opacity: 1;
	text-indent: -999em;
}
.mfp-image-holder .mfp-arrow { display: none;}
.mfp-image-holder .mfp-bottom-bar {
	background: rgba(0, 0, 0, 0.5);
	display: inline-block!important;
	margin-top: 0!important;
	position: absolute!important;
	right: 0!important;
	bottom: 0!important;
	left: auto!important;
	top: auto!important;
	width: auto!important;
	padding: 3px 5px;
	text-align: center!important;
	z-index: 1!important;
}
.mfp-image-holder .mfp-bottom-bar .mfp-title {
	color: #FFF;
	padding-right: 0;
}
.mfp-image-holder .mfp-bottom-bar .mfp-counter { display: none!important;}
@media screen and (max-width: 767px) {
	.mfp-wrap,
	.mfp-bg { min-width: auto;}
	.mfp-image-holder .mfp-content { max-width: 95%!important;}
	.mfp-image-holder .mfp-close,
	.mfp-image-holder .mfp-close:focus,
	.mfp-image-holder .mfp-close:active {
		height: 30px!important;
		width: 30px!important;
		top: -40px!important;
	}
}

/* */
header .clioLogo {
	padding: 0;
	position: absolute;
	top: 30px;
	left: 30px;
	z-index: 1;
}
.out_vh header .clioLogo {
  opacity: 0;
  visibility: hidden;
}
@media only screen and (max-width: 767px) {
  header .clioLogo img {
    width: 70px;
  }
}

.note_wrap{margin-top: 60px;}
.note{font-size: 10px; line-height: 1.6;}
@media only screen and (max-width: 767px) {
	.note_wrap{margin-top: 30px;}
}