/* CSS Document */



/*************************************************************
メインビジュアル
*************************************************************/
#mv{
	background-image: url("../img/top/mv-back01@2x.webp");
	width: 100%;
	aspect-ratio: 1918 / 1159;
	background-size: cover;
    background-position: center;
	
	position: relative;
}

#mv .tel-btn{
	position: absolute;
	width: 16.9rem;
	bottom:35.8%;
	right: 3.9%;
	z-index: 100;
}


@media (max-width: 1440px) {
	#mv .tel-btn{
		bottom: 22.8%;
	}
	
	@media (max-width: 1024px) {
		#mv .tel-btn{
			width: 13.4rem;
			bottom: 15%;
		}
		
		@media (max-width: 840px) {
			#mv .tel-btn {
				bottom: 13%
			}
			
			@media (max-width: 520px) {
				#mv .tel-btn {
					bottom: 8%;
					width: 9rem;
				}
				
				#mv{
					height: 65rem;
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}


/*************************************************************
インフォメーション
*************************************************************/
#info{
	position: relative;
	background-color: #ffffe9;
	color: #00636c;
	padding-bottom: 21em;
}
#info:before {
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 1918 / 446;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 0;
	background-image: url("../img/top/info-back-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#info .inner{
	padding-bottom: 57rem;
	position: relative;
}

#info .info-title{
	margin: 0 auto;
	width: 94%;
	aspect-ratio: 1105 / 79;
}

#info h2.info-txt{
	font-size: 3rem;
	letter-spacing: 0.1em;
	font-weight: 600;
    margin: 2.4em 0 0.8em 0.1em;
}

#info p.info-txt{
	font-size: 1.9rem;
	letter-spacing: 0.1em;
	line-height: 2.2;
	margin: 0 auto;
}

#info .gallery-abs-box{

}
#info .gallery-abs-box .abs-box{
	position: absolute;
	width: 40.6rem;
}
#info .gallery-abs-box .abs-box.first{
	aspect-ratio: 450 / 489;
    width: 38%;
	bottom: 31.8%;
	right: 98.1%;
}
#info .gallery-abs-box .abs-box.second{
	aspect-ratio: 467 / 442;
    width: 40%;
	bottom: 4%;
	left: 4.5%;
}
#info .gallery-abs-box .abs-box.third{
	aspect-ratio: 487 / 489;
    width: 41.4%;
	bottom: 3.3%;
	right: 1.4%;
}
#info .gallery-abs-box .abs-box.fourth{
	aspect-ratio: 458 / 485;
    width: 39%;
	bottom: 37.3%;
	left: 98.2%;
}

@media (max-width: 1440px) {
	#info .gallery-abs-box .abs-box.first{
		width: 34%;
		right: 86.1%;
	}
	
	#info .gallery-abs-box .abs-box.second{
		width: 36%;
		left: 10.5%;
	}
	
	#info .gallery-abs-box .abs-box.third{
		width: 36.4%;
		right: 11.4%;
	}
	
	#info .gallery-abs-box .abs-box.fourth{
		width: 35%;
		bottom: 33%;
		left: 84%;
	}

	@media (max-width: 1024px) {
	#info .gallery-abs-box .abs-box.second{
		left: 8.5%;
	}
	
	#info .inner{
		padding-bottom: 40rem;
	}
		
	#info p.info-txt{
		font-size: 1.7rem;
		line-height: 3.7rem;
	}
		@media (max-width: 840px) {
			#info {
				padding-bottom: 13em;
			}
			
			#info p.info-txt {
				font-size: 1.6rem;
			}
			
			#info .gallery-abs-box .abs-box.first{
				right: 88%;
			}
			
			#info .gallery-abs-box .abs-box.fourth{
				left: 86%;
			}
			
			#info .inner{
				padding-bottom: 32rem;
			}
			
			#info h2.info-txt {
				margin-top: 1.7em;
			}

			@media (max-width: 520px) {
				#info{
					padding-bottom: 8em;
				}
				
				#info:before {
					aspect-ratio: 1920 / 669;
					background-size: 150%;
				}
				
				#info .inner{
					padding-bottom: 16rem;
				}
				
				#info .info-title{
					width: 94%;
					aspect-ratio: 649 / 179;
					padding-top: 4%;
				}
				
				#info h2.info-txt {
					margin-top: 1.2em;
					margin-bottom: 0.6em;
					font-size: 2rem;
				}
				
				#info p.info-txt{
					font-size: 1.2rem;
					line-height: 2.2;
					width: 70%;
					margin: 0 auto;
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}


/*************************************************************
ニュース
*************************************************************/
#news{
	background-color: #00636c;
	position: relative;
	padding-bottom: 19.6em;
}

#news:before{
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 1918 / 464;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 0;
	background-image: url("../img/top/news-back-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#news .news-title{
	width: 46%;
	aspect-ratio: 203 / 99;
}

#news .left-box{
	border-left: 6px solid #ffffe9;
	padding: 0 0 0 1.5em;
}
#news .right-box{
	width: 55%;
}

#news .news-txt{
	font-size: 2rem;
	letter-spacing: 0.1em;
	color:  #ffffe9;
	padding: 2.2em 0 2.2em 0.4em;
}

#news .news-btn{
  font-size: 1.5rem;
  letter-spacing: 0.05em;
  align-items: center;
  padding: 1em 2em 1em 2em;
  margin-bottom: 2em;
  color: #ffffe9;
  background: #ff7514;
  border-radius: 5rem;
  box-shadow: 0 0.5rem 0 #383a39;
}

#news .news-btn:active{
  top: 0.5rem;
    box-shadow: 0 0 0 #383a39;
}

#news .news-list{
	position: relative;
	padding: 0.2em;
	list-style-type: none;
	margin-top: 0.4em;
}

#news .news-item{
  margin-bottom: 2em;
  color: #00636c;
  background: #ffffe9;
  border-radius: 2rem;
}

#news .news-item:last-of-type {
    margin-bottom: 0;
}

#news .news-item a{
  padding: 1.6em 9.7em 1.6em 3.5em;
	display: block;
}

#news .news-item:after{
	content: '';
	display: block;
	max-width: 4.25rem;
	width: 100%;
	aspect-ratio: 85 / 86;
	position: absolute;
	left: 95%;
	transform: translateY(-124%);
	background-image: url("../img/top/news-button-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#news .ttl{
	font-size: 2rem;
	letter-spacing: 0.1em;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}

#news .date{
	font-size: 1.5rem;
}

@media (max-width: 1440px) {
	
	@media (max-width: 1024px) {
		#news{
		  padding-bottom: 13.5em;
		}
		
		#news .news-title{
		  width: 30%;
		}
		
		#news .left-box{
			padding: 0 0 2.1em 1.5em;
			margin-bottom: 2em;
		}
		
		#news .news-txt,
		#news .ttl{
			font-size: 1.7rem;
		}
		
		#news .news-txt{
			padding-top: 1.4em;
		}
		
		#news .news-item a{
		  padding: 1.5em 7em 1.5em 3.5em;
		}
			
		#news .flex-wrap{
			justify-content: center;
		}
		
		#news .left-box,
		#news .right-box{
			max-width: 80rem;
			width: 100%;
		}
		
		#news .news-item:after{
			left: 96.3%;
		}
		
		@media (max-width: 840px) {
			
			@media (max-width: 520px) {
				#news{
					padding-bottom: 7em;
				}
				
				#news:before {
					aspect-ratio: 1920 / 696;
					background-size: 150%;
				}
				
				#news .news-txt{
					font-size: 1.2rem;
				}
				
				#news .news-btn{
					font-size: 1.2rem;
				}
				
				#news .left-box {
					padding: 0 0 1.7em 0.9em;
					margin-bottom: 1em;
				}
				
				#news .ttl {
					font-size: 1.2rem;
				}
				
				#news .date {
					font-size: 1.2rem;
				}
				
				#news .news-title{
					width: 38%;
				}
				
				#news .news-item a{
					padding: 1em 2em;
				}
				
				#news .news-item:after {
					left: 93.3%;
					width: 9%;
				}
				
				#news .news-item{
					margin-bottom: 1em;
					border-radius: 1rem;
				}
				
				#news .news-item:last-of-type {
					margin-bottom: 0;
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}

/*************************************************************
料金
*************************************************************/
#price{
	background-color: #00a943;
	position: relative;
	padding-bottom: 34em;
}

#price:before{
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 1919 / 171;
	position: absolute;
	bottom: 100%;
	left: 0;
	background-image: url("../img/top/price-back-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#price .abs-back01{
	display: block;
	width: 25.8%;
	aspect-ratio: 550 / 214;
	position: absolute;
	bottom: 88%;
	right: 5.4%;
	background-image: url("../img/top/price-back-02@2x.webp");
	background-size: cover;
	background-position: center;
}

#price .abs-back02{
	display: block;
	width: 50%;
	aspect-ratio: 1089 / 1016;
	position: absolute;
	bottom: 17%;
	left: 0;
	background-image: url("../img/top/price-back-03@2x.webp");
	background-size: cover;
	background-position: center;
}

#price .abs-back03{
	display: block;
	width: 57%;
	aspect-ratio: 1414 / 1001;
	position: absolute;
	bottom: 8.3%;
	right: 0;
	background-image: url("../img/top/price-back-04@2x.webp");
	background-size: cover;
	background-position: center;
}

#price .inner{
	position: relative;
}

#price .abs-box{
	position: absolute;
	width: 26%;
	aspect-ratio: 456 / 459;
	top: 90%;
	left: 84%;
}

#price .img-box{
	width: 23.7%;
	aspect-ratio: 226 / 95;
}

#price .price-box{
	margin: 0 8em;
	padding-top: 3.8em;
}

#price .txt{
	font-size: 1.9rem;
	color: #ffffe9;
	letter-spacing: 0.1em;
	line-height: 2.3;
	margin-left: 3.9em;
}

#price .price-title.flex-wrap{
	justify-content: flex-start;
	align-items: center;
	flex-wrap: wrap;
	margin-bottom: 4em;
}

#price .price-img-box{
	position: relative;
	width: 100%;
	aspect-ratio: 1015 / 678;
	z-index: 100;
}

@media (max-width: 1440px) {
	#price .abs-box{
		width: 20%;
	}
	
	@media (max-width: 1024px) {
		#price{
			padding-bottom: 15.9em;
		}
		
		#price .txt{
			font-size: 1.7rem;
			line-height: 2;
			margin-left: 1.2em;
		}
		
		#price .abs-back01{
			width: 24%;
		}
		
		#price .abs-back02{
			width: 48%;
			bottom: 30%;
		}
		
		#price .abs-back03{
			width: 52%;
			bottom: 10%;
		}
		
		#price .abs-box{
			left: 81%;
		}
		
		@media (max-width: 840px) {
			#price{
				padding-bottom: 12em;
			}
			
			#price .price-title.flex-wrap {
				margin-bottom: 2em;
			}
			
			#price .txt{
				margin-left: 0;
			}
			
			#price .abs-box{
				left: 77.8%;
			}
			
			#price .img-box {
				width: 40%;
				padding-bottom: 1em;
			}
			
			#price .price-box {
				padding-top: 0.5em;
			}
			
			@media (max-width: 520px) {
				#price{
					padding-bottom: 7.5em;
				}
				
				#price:before {
					aspect-ratio: 1920 / 256.5;
					background-size: 150%;
				}
				
				#price .price-box{
					margin: 0;
				}
				
				#price .txt{
					font-size: 1.2rem;
					line-height: 1.7;
				}
				
				#price .abs-back01 {
					bottom: 85%;
					width: 36%;
				}
				
				#price .abs-back03 {
					bottom: 10.6%
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}

/*************************************************************
クラブハウス
*************************************************************/
#clubhouse{
	background-color: #ffffe9;
	position: relative;
	padding-bottom: 62em;
}

#clubhouse:before{
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 1920 / 205;
	position: absolute;
	bottom: 100%;
	left: 0;
	background-image: url("../img/top/clubhouse-back-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#clubhouse .inner{
	z-index: 1;
    position: relative;
}

#clubhouse .clubhouse-title{
	width: 36%;
	aspect-ratio: 418 / 77;
	margin:0 auto;
	padding-top: 2em;
}

#clubhouse h2{
	color: #00a943;
	font-size: 1.75rem;
	letter-spacing: 0.1em;
	line-height: 2.3;
	margin: 1.8em 0;
}

#clubhouse .scroll-infinity__content{
	position: absolute;
	top: 15.8%;
}

@keyframes infinity-scroll-left {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}


.scroll-infinity {
  overflow: hidden;
}

.scroll-infinity__wrap {
  display: flex;
  width: 100%;
}

.scroll-infinity__content {
  display: flex;
  width: fit-content;
  animation: infinity-scroll-left 30s linear infinite;
}

.scroll-infinity__content img {
	max-width: initial;
  width: 217rem;
/*   flex-shrink: 0; */
}

@media (max-width: 1440px) {
	
	@media (max-width: 1024px) {
		#clubhouse{
			padding-bottom: 50em;
		}
		
		.scroll-infinity__content img {
			width: 165rem;
		}
		
		#clubhouse .scroll-infinity__content{
			top: 23.8%;
		}
		
		@media (max-width: 840px) {
			#clubhouse{
				padding-bottom: 48em;
			}
			
			#clubhouse .scroll-infinity__content{
				top: 20%;
			}
			
			#clubhouse .clubhouse-title {
				width: 45%;
			}
			
			#clubhouse h2 {
				margin: 1.5em 0;
			}
			
			@media (max-width: 520px) {
				#clubhouse{
					padding-bottom: 32em;
				}
				
				#clubhouse:before {
					aspect-ratio: 1920 / 306;
					background-size: 150%;
				}
				
				#clubhouse .clubhouse-title {
					width: 60%;
				}
				
				#clubhouse h2 {
					margin: 1em 0;
					font-size: 1.2rem;
					line-height: 1.7;
				}
				
				.scroll-infinity__content img {
					width: 115rem;
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}

/*************************************************************
マップ
*************************************************************/
#map{
	background-color: #00636c;
	position: relative;
	padding: 10rem 0 17.6rem;
}

#map:before{
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 1920 / 240;
	position: absolute;
	bottom: calc(100% - 1px);
	left: 0;
	background-image: url("../img/top/contact-back-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#map .map_inner{
	max-width: 161.6rem;
	margin:0 auto;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	flex-wrap: nowrap;
	width: 86%;
	position: relative;
}

#map .addr{
	width: 35%;
	aspect-ratio: 565 / 545;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	
	display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1;
	
	background-image: url("../img/top/map-img-01@2x.webp");
	background-size: cover;
	background-position: center;
}

#map .addr .addr-inner{
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: center;
	width: 80%;
	max-width: 30rem;
}



#map .logo-box{
	width: 30rem;
}


#map .addr-txt,
#map .notice{
	font-size: 1.8rem;
	letter-spacing: 0.2em;
    margin-top: 0.6em;
    margin-left: 0.5em;
	color: #00636c;
}

#map .en{
	font-size: 1.9rem;
	letter-spacing: 0.15em;
}

#map .addr-txt{
	padding: 1.1em 0;
	line-height: 1.5;
}

#map .notice{
	line-height: 2;
}

#map .googlemap{
	aspect-ratio: 1262 / 622;
	width: 78.3%;
	border-radius: 3rem;
}

@media (max-width: 1440px) {
	#map .logo-box{
		width: 28rem;
	}
		
	@media (max-width: 1024px) {
		#map{
			padding: 11rem 0 11.6rem;
		}
		
		#map .addr-txt,
		#map .notice{
			font-size: 1.4rem;
			margin-top: 0.4em;
		}

		#map .logo-box{
			width: 20rem;
		}	
		
		#map .en{
			font-size: 1.4rem;
		}
		
		#map .addr .addr-inner{
			margin-left: 2.3em;
		}
		
		@media (max-width: 840px) {
			#map {
				padding: 8rem 0;
			}
			
			#map .logo-box {
				width: 17rem;
			}
			
			#map .addr-txt, 
			#map .notice {
				margin-top: 0;
				margin-left: 0;
			}
			
			#map .addr-txt {
				padding: 0.8em 0;
			}
			
			#map .notice {
				line-height: 1.6;
			}
			
			#map .googlemap {
				aspect-ratio: 1250 / 700;
			}

			
			@media (max-width: 520px) {
				#map {
					padding: 35rem 0 5rem;
				}
				
				#map:before {
					aspect-ratio: 1920 / 360;
					background-size: 150%;
				}
				
				#map .addr{
					width: 80%;
					top: auto;
					left: auto;
					margin: 0 auto;
					transform: translateY(-115%);
				}
				
				#map .addr-inner{
					margin: 0 auto;
				}
				
				#map .map_inner{
					width: 94%;
					margin: 0 auto;
					justify-content: center;
				}
				
				#map .logo-box{
					width: 21.5rem;
				}
				
				#map .en{
					font-size: 1.35rem;
				}
				
				#map .addr-txt,
				#map .notice{
					font-size: 1.3rem;
				}
				
				#map .googlemap{
					border-radius: 1.2rem;
					aspect-ratio: 1 / 1;
				}
				
				@media (max-width: 375px) {
					
				}
			}
		}
	}
}

/*************************************************************
お問い合わせ
*************************************************************/
#contact{
	background-color: #00636c;
	position: relative;
	padding-bottom: 30.1em;
}

#contact .map_inner{
	max-width: 161.6rem;
	width: 86%;
	margin:0 auto;
	position: relative;
}

#contact .addr{
	background-image: url("../img/top/contact-back-02@2x.webp");
	background-size: cover;
	background-position: center;
	max-width: 157.7rem;
	width: 100%;
	height: auto;
	aspect-ratio: 1557 / 583;
	margin-left: 1.5em;
}

#contact .flex-box{
	position: absolute;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: nowrap;
	width: 100%;
	left: 0;
	top: 23%;
}

#contact .ttl-box{
	width: 81%;
	aspect-ratio: 339 / 96;
}

#contact .left-box{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	flex-wrap: wrap;
	margin-right: 5em;
	margin-bottom: 2em;
}

#contact .ttl-box{
	margin-bottom: 3.5em;
}

#contact .left-box p{
	color: #ffffe9;
	font-size: 1.9rem;
	letter-spacing: 0.1em;
	line-height: 1.7;
}

#contact .contact-button{
  background-color: #ffffe9;
    border-radius: 6rem;
    box-shadow: 0 0.9rem 0 #00636c;
    color: #00636c;
    display: block;
	font-size: 2.62rem;
    padding: 0.8em 1.9em 0.8em 0;
    position: relative;
    text-align: center;
    text-decoration: none;
    width: 100%;
	max-width: 41.8rem;
	margin-bottom: 0.9em;
	letter-spacing: 0.1em;
	font-weight: 600;
}

#contact .contact-button::after{
    content: '';
    display: inline-block;
    border-width: 1.5rem 0 1.5rem 2.5rem;
    border-color: transparent transparent transparent #00636c;
    position: absolute;
    top: 52%;
    right: 3.4rem;
    transform: translateY(-50%);
}

#contact .contact-button:hover{
  top: 0.9rem;
    box-shadow: 0 0 0 #00636c;
}

@media (max-width: 1440px) {
	#contact .flex-box{
	top: 16%;
    }
	
	@media (max-width: 1024px) {
		#contact{
			padding-bottom: 20.5em;
		}
		
		#contact .flex-box{
			transform: scale(0.7);
			top: 5%;
		}        
		
		#contact .left-box p{
			font-size: 1.7rem;
			line-height: 1.9;
		}
		
		#contact .contact-button:hover{
		    top: 0.7rem;
		}
		
		@media (max-width: 840px) {
			#contact .flex-box {
				transform: scale(0.8);
				top: 5%;
			}
			
			#contact .contact-button {
                box-shadow: 0 0.7rem 0 #00636c;
                font-size: 1.7em;
                padding: 0.6em 1.6em 0.6em 0.5em;
                width: 46.9%;
            }
			
			#contact .addr {
				margin-left: 0;
			}
			
			#contact .contact-button::after {
				border-width: 1rem 0 1rem 1.6rem;
				top: 51%;
				right: 2.4rem;
			}
			
			#contact .ttl-box {
				width: 70%;
				margin-bottom: 1.5em;
			}
			
			#contact .left-box{
				margin-bottom: 0;
				margin-right: 0.3em;
			}
			
			#contact .left-box p{
				font-size: 1.6rem;
			}
			
			#contact{
				padding-bottom: 15.5em;
			}
			
			@media (max-width: 650px) {
				#contact .flex-box {
					top: 4%;
				}
				
				#contact .ttl-box {
					width: 60%;
				}
				
				#contact .contact-button {
					font-size: 1.6em;
				}
				
				#contact .left-box{
					margin-right: -12%;
				}
				
				#contact .contact-button{
					margin-bottom: 0;
				}
			
				@media (max-width: 520px) {
					#contact {
						padding-bottom: 12.7em;
					}
					
					#contact .flex-box{
						flex-direction: column;
					}
					
					#contact .left-box p {
						font-size: 1.2rem;
						text-align: center;
						line-height: 1.75;
						margin-bottom: 2em;
						margin-left: 4%;
					}
					
					#contact .left-box{
						align-items: center;
						margin: 0 auto;
					}
					
					#contact .contact-button {
						font-size: 1.3rem;
						width: 80%;
					}
					
					#contact .flex-box{
						position: relative;
						top: 0;
					}
					
					#contact .addr{
						background-image: url("../img/top/contact-back-03@2x.webp");
						width: 85.4%;
						aspect-ratio: 1 / 1;
						margin:0 auto;
						border-radius: 1.2rem;
						box-shadow: 0 0.5rem 0 #373a39;
						display: flex;
                        justify-content: center;
                        align-items: center;
					}
					
					#contact .contact-button{
						box-shadow: 0 0.5rem 0 #00636c;
					}
					
					#contact .contact-button::after {
						border-width: 0.8rem 0 0.8rem 1.3rem;
					}
					
					#contact .contact-button:hover{
						top: 0.5rem;
					}

					@media (max-width: 375px) {
						
					}
				}
			}
		}
	}
}