@charset "utf-8";

/*-------------- all --------------*/


.btns { display: block; width: 320px; border: 1px solid #9a8b68; padding: 22px 0; font-size: 14px; text-align: center; letter-spacing: 0.04em; color: #bdb28f; font-weight: 700;}
.view { font-weight: 700; letter-spacing: 0.04em; color: #bdb28f; text-decoration: underline; text-decoration-color: #bdb28f; text-underline-offset: 9px;}
h3{ font-size: 20px; letter-spacing: 0.04em; font-weight: 500; text-align: center; }

/*-------------- fv --------------*/

#fv .fv { background: url(../images/stay/fv.jpg) no-repeat center center / cover;}
#fv h2{ padding: 50px 0 0; font-size: 20px; letter-spacing: 0.04em; text-align: center;}
#fv h2 img { display: block; margin: 0 auto 20px;}


/*-------------- course --------------*/
.modelcourse { margin-bottom: 122px;}
#course01.modelcourse { padding-top: 120px;margin-bottom: 175px;}
.modelcourse .top { }
.modelcourse .top h3 {　font-size: 20px; font-weight: 700; margin-bottom: 80px;}
.modelcourse .top h3 span { display: block; font-size: 50px; font-weight: 700; margin-top: 25px;}
.modelcourse .top h3 img { display: block; margin: 20px auto 0;}

.modelcourse .stay { }
.modelcourse #day1.stay { margin-bottom: 114px;}
.modelcourse #day2.stay {}
.modelcourse .stay .day { border-bottom: 1px solid #000; padding-bottom: 32px; margin-bottom: 44px;}
.modelcourse .stay h4 {  font-size: 40px; font-weight: 500; text-align: center; font-family: "Helvetica Neue", Arial, source-han-sans-cjk-ja, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;}
.modelcourse .stay h4 span { font-size: 45px; letter-spacing: 0; font-weight: 100; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;}
.modelcourse .stay .flex { display: flex; justify-content: space-between;     align-items: center;}
.modelcourse .stay .flex .left { width: 50%;}
.modelcourse .stay .flex .left .title { font-size: 60px; font-weight: 500; color: #b2b2b2; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; margin-bottom: 25px;}
.modelcourse .stay .flex .left .time { font-size: 31px; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; font-weight: 500; margin-bottom: 28px;}
.modelcourse .stay .flex .left .time img { vertical-align: -4px;}
.modelcourse .stay .flex .left h5 { font-size: 40px; font-weight: 700; margin-bottom: 20px;}
.modelcourse .stay .flex .left h5 span { font-size: 24px; font-weight: 700; font-feature-settings: "palt";}
.modelcourse .stay .flex .left .main { font-size: 16px; font-weight: 300; line-height: 2;font-feature-settings: "palt";}
.modelcourse .stay .flex .left a { display: block; width: 320px; line-height: 60px; font-size: 14px; color: #000; border: 1px solid #7d7d7d; text-align: center; margin-top: 22px;}
.modelcourse .stay .flex .left a:hover { background: #7d7d7d; color: #fff;}
.modelcourse .stay .flex .right { width: 50%;}

.modelcourse .stay .tips { position: relative; display: flex; align-items: center; padding: 19px 16px; border: 1px solid #c9c9c9;}
.modelcourse .stay .tips01 { margin-bottom: 15px;}
.modelcourse .stay .tips img { }
.modelcourse .stay .tips .tipsabs { position: absolute;}
.modelcourse .stay .tips div { margin-left: 43px;}
.modelcourse .stay .tips h5 { font-size: 24px; letter-spacing: 0.04em; font-weight: 500; margin-bottom: 15px;}
.modelcourse .stay .tips p { font-size: 16px; line-height: 1.75; }
.modelcourse .stay .tips a { display: block; width: 320px; line-height: 38px; font-size: 14px; color: #000; border: 1px solid #7d7d7d; text-align: center; margin-top: 12px;}
.modelcourse .stay .tips a:hover { background: #7d7d7d; color: #fff;}

.modelcourse .stay .imgless { display: flex; align-items: flex-end;}
.modelcourse .stay .imgless img { }
.modelcourse .stay .imgless h5 { font-size: 40px; font-weight: 700; margin: 0 49px;}
.modelcourse .stay .imgless .title { font-size: 60px; font-weight: 500; color: #b2b2b2; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;}
.modelcourse .stay .imgless .main { font-size: 16px; font-weight: 300; line-height: 2;}

#course01.modelcourse .stay .imgless{position: relative;}
#course01.modelcourse .stay .imgless .title{line-height: 50px;}
#course01.modelcourse .stay .imgless h5{line-height: 40px;}
#course01.modelcourse .stay .imgless .main{line-height: 16px;}

.modelcourse .stay .course { margin-bottom: 30px;}
.modelcourse .stay .course:after { display: block; content: ""; width: 2px; height: 50px; background-color: #eae8e4; margin: 0 auto; margin-top: 30px;}
.modelcourse #day1.stay .course01 { }
.modelcourse #day1.stay .course01 .flex { position: relative; margin-bottom: 26px;}
.modelcourse #day1.stay .course01 .left { width: 460px;}
.modelcourse #day1.stay .course01 .right { width: 486px; height: auto;}
.modelcourse #day1.stay .course01 .right:last-child { position: absolute; width: 250px; height: auto; bottom: 0; right: 330px;}

.modelcourse #day1.stay .course02 { }
.modelcourse #day1.stay .course02 .flex { position: relative; margin-bottom: 40px;}
.modelcourse #day1.stay .course02 .left { width: 460px;}
.modelcourse #day1.stay .course02 .right { width: 486px; height: auto;}
.modelcourse #day1.stay .course02 .right:last-child { position: absolute; width: 250px; height: auto; bottom: 0; right: 330px;}
.modelcourse #day1.stay .course02 .tips .tipsabs { top: -30px; left: -70px; width: 92px; padding: 17px 0 25px; background: #0f122d; border-radius: 50%;  box-shadow: 0px 10px 15px 0px rgba(0, 0, 0, 0.2); text-align: center;}
.modelcourse #day1.stay .course02 .tips .tipsabs p{ font-size: 20px; font-weight: 700; color: #fff; line-height: 1.25;}
.modelcourse #day1.stay .course03 { }
.modelcourse #day1.stay .course03 .flex { margin-bottom: 40px;}
.modelcourse #day1.stay .course03 .left { width: 500px;}
.modelcourse #day1.stay .course03 .tips .tipsabs { position: static; margin: 0 20px 0 36px; }
.modelcourse #day1.stay .course03 .tips div { margin-left: 0;}
.modelcourse #day1.stay .course04 { }
.modelcourse #day1.stay .course04 h4 { font-weight: 700; margin-bottom: 74px;}
.modelcourse #day1.stay .course04 .flex { margin-bottom: 40px; padding-bottom: 40px; border-bottom: 2px solid #c9c9c9;}
.modelcourse #day1.stay .course04 .flex .left { width: 50%;}
.modelcourse #day1.stay .course04 .flex:nth-child(2) .left { width: 520px;}
.modelcourse #day1.stay .course04 .flex:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: 0px;}
.modelcourse #day1.stay .course04 .flex .right { width: 500px;}
.modelcourse #day1.stay .course05 { }

.modelcourse #day2.stay .course01 { }
.modelcourse #day2.stay .course02 { }
.modelcourse #day2.stay .course03 { }
.modelcourse #day2.stay .course03 .flex { position: relative; margin-bottom: 47px;}
.modelcourse #day2.stay .course03 .right:last-child { position: absolute; width: 203px; height: auto; bottom: -10px; right: 495px;}
.modelcourse #day2.stay .imgless { margin-bottom: 41px;}
.modelcourse #day2.stay .imgless div { margin: 0 49px;}
.modelcourse #day2.stay .imgless h5 { margin: 0;}
.modelcourse #day2.stay .imgless .time { font-size: 31px; font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif; font-weight: 500; margin-bottom: 12px;}

.modelcourse #day2.stay .imgless .main { line-height: 2; }
.modelcourse #day2.stay .tips { padding: 23px 16px 20px 28px;}


.modelcourse .slide { position: relative;}
.modelcourse .slider {  width: 100%; margin: 0 auto;}
.modelcourse .slider .slick-list { height: auto; }
.modelcourse .slider .slick-list.slick-list-img{margin: 0 18px;}
.modelcourse .slider img { width: 100%; height: 100%; object-fit: cover;}
.modelcourse .slider .slick-dots { position: absolute; bottom: -54px;}
.modelcourse .slider .slick-dots li { width: 14px; height: 14px; margin: 0 10px; background-color: #c9c9c9; border-radius: 50%;}
.modelcourse .slider .slick-dots li.slick-active { background-color: #8c0000;}
.modelcourse .slider .slick-dots li button::before { color: transparent;}



/*-------------- other --------------*/

#other { text-align: center; padding: 100px 0; border-top: 1px solid #c9c9c9;}
#other .other { width: 685px; margin: 0 auto;}
#other h3 { font-size: 20px; font-weight: 700; margin-bottom: 58px;}
#other h3 span { display: block; font-size: 50px; font-weight: 700; margin-top: 24px;}
#other h3 img { display: block; margin: 20px auto 0;}
#other .reco { margin-bottom: 100px;}
#other .reco:last-child { margin-bottom: 0;}
#other .reco h4 { display: flex; justify-content: space-between; align-items: center; margin-bottom: 36px;}
#other .reco h4 span { display: inline-block; margin: 0 auto; }
#other .reco h4 span .rec { display: block; margin: 0 auto 19px;}
#other .reco h4 span .num { display: block; margin: 0 auto;}

#other .reco h4:before,
#other .reco h4:after { display: inline-block; content: ""; width: 200px; height: 2px; background: #000; margin: 35px 0 0;}
#other .reco h5 { font-size: 30px; font-weight: 700; margin-bottom: 22px;}

#other .reco .course { margin-bottom: 50px; padding-bottom: 50px; border-bottom: 2px dotted #c9c9c9;}
#other .reco .course:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: 0px;}
#other .reco .course .title { width: 100%; line-height: 60px; font-size: 24px; font-weight: 700; color: #fff; background-color: #000; margin-bottom: 40px;}


#other .reco .course { }


#other .reco .course .sauna { width: 100%; padding: 30px 35px; margin-top: 40px; border: 1px solid #c9c9c9; text-align: start;}
#other .reco .course .sauna h6 { font-size: 20px; font-weight: 500; margin-bottom: 24px;}
#other .reco .course .sauna h6:before { content: ""; display: inline-block; width: 6px; height: 26px; background: #000; margin-right: 14px; vertical-align: -6px;}
#other .reco .course .sauna p { font-size: 16px; line-height: 1.75;}


/* ----------------------------- mobile ------------------------------- */
@media only screen and (max-width: 768px) {
	
	/*-------------- all --------------*/
	
	.btns { display: block; width: 80%; margin: 0 auto; padding: 18px 0; font-size: 12px; background-color: #fff;}
	.view { }
	h3 { font-size: 15px;}
	h3 span { font-size: 40px; margin-bottom: 11px;}
	nav ol {    padding: 115px 0 0px;}
	
	/*-------------- fv --------------*/
	
	#fv .fv { background: url(../images/stay/fv_sp.jpg) no-repeat center center / cover;}
	#fv h2 img {display: block; margin: 0 auto 15px; width: 35%; }
    /*-------------- about --------------*/
	
	#about { padding: 50px 0 75px;}
	#about h2 { font-size: 15px; margin-bottom: 25px;}
	#about h2 span { font-size: 25px; margin-top: 19px;}
	#about p { font-size: 13px; letter-spacing: 0; margin-bottom: 35px;}
	
	#about .slide { position: relative;}
	#about .slider {  width: 100%; margin: 0 auto;}
	#about .slider .slick-list { height: 200px; margin: 0 5px; }
	#about .slider .slick-list img { width: 200px; height: auto;}
	#about .slider .slick-dots { bottom: -10px;}
	#about .slider .slick-dots li { width: 10px; height: 10px; margin: 0 5px;}
	
	
	/*-------------- course --------------*/
	#course01 { padding-top: 60px;}
	#course01.modelcourse {padding-top: 60px;;margin-bottom: 80px;}
	.modelcourse { margin-bottom: 50px;}
	.modelcourse .top {  margin-bottom: 35px;}
	.modelcourse .top h3 { margin-bottom: 35px;}
	.modelcourse .top h3 span { font-size: 36px;}
	.modelcourse .top h3 img { width: 240px; height: auto;}
	
	.modelcourse .stay { }
	.modelcourse #day1.stay { margin-bottom: 55px;}
	.modelcourse #day2.stay { }
	
	.modelcourse .stay .day { padding-bottom: 12px; margin-bottom: 22px;}
	.modelcourse .stay h4 { font-size: 25px; /* margin-bottom: 40px; */}
	.modelcourse .stay h4 span { font-size: 30px;}
	.modelcourse .stay h4:after { width: 100%; height: 30px; top: 35px;}
	.modelcourse .stay .flex { display: block;}
	.modelcourse .stay .flex .left { width: 100%; margin-bottom: 20px;}
	.modelcourse .stay .flex .left .title { font-size: 40px; margin-bottom: 15px;}
	.modelcourse #day1.stay .course04 .flex { margin-bottom: 25px; padding-bottom: 25px;}
	.modelcourse .stay .flex .left .time { font-size: 20px; margin-bottom: 17px; display: flex; align-items: center;}
	.modelcourse .stay .flex .left .time img { vertical-align: -4px; margin: 0 6px 0 0;}
	.modelcourse .stay .flex .left h5 { font-size: 25px; margin-bottom: 15px;}
	.modelcourse .stay .flex .left h5 span { font-size: 12px;}
	.modelcourse .stay .flex .left .main { width: 100%; font-size: 13px; line-height: 1.769;}
	.modelcourse .stay .flex .left a { width: 80%; line-height: 48px; font-size: 12px; margin: 22px auto 0;}

	.modelcourse .stay .flex .right { width: 100%;}
	
	.modelcourse .stay .tips { display: block; padding: 25px 25px 13px; width: 90%; margin: 0 auto 20px;}
	.modelcourse .stay .tips img { width: 100%; height: auto; margin-bottom: 15px;}
	.modelcourse .stay .tips .tipsabs { }
	.modelcourse .stay .tips div { margin-left: 0;}
	.modelcourse .stay .tips h5 { font-size: 15px; margin-bottom: 5px; line-height: 1.5; text-align: center;font-feature-settings: "palt";}
	.modelcourse .stay .tips p { font-size: 13px; line-height: 1.769; }
	.modelcourse .stay .tips a {width: auto; line-height: 40px; font-size: 12px; margin-top: 12px; }
	.modelcourse .stay .tips small{font-size: 11px;}
	
	.modelcourse .stay .imgless { display: block;}
	.modelcourse .stay .imgless img { }
	.modelcourse .stay .imgless .title { font-size: 40px; padding: 0 0 20px;}
	.modelcourse .stay .imgless h5 { font-size: 25px; margin: 0 0 16px;}
	.modelcourse .stay .imgless p { font-size: 13px;}
	.modelcourse .stay .imgless .main { font-size: 13px;}
	#course01.modelcourse .stay .imgless .title{line-height: 1;}
	#course01.modelcourse .stay .imgless h5{line-height: 1;}
	#course01.modelcourse .stay .imgless .main{line-height: 2;}
	
	.modelcourse .stay .course { margin-bottom: 20px;}
	.modelcourse .stay .course:after { width: 2px; height: 35px; margin-top: 20px;}
	.modelcourse #day1.stay .course01 { }
	.modelcourse #day1.stay .course02 { }
	.modelcourse #day1.stay .course01 .flex,
	.modelcourse #day1.stay .course02 .flex { margin-bottom: 70px; text-align: left;}
	.modelcourse #day1.stay .course01 .left,
	.modelcourse #day1.stay .course02 .left { width: 100%; text-align: left;}
	.modelcourse #day1.stay .course01 .right ,
	.modelcourse #day1.stay .course02 .right { width: 80%; height: auto; margin: 0 0 0 auto; display: block;}
	.modelcourse #day1.stay .course01 .right:last-child ,
	.modelcourse #day1.stay .course02 .right:last-child { width: 45%; height: auto; bottom: -35px; left: 0px; right: 55%;}
	.modelcourse #day1.stay .course01 .tips .tipsabs,
	.modelcourse #day1.stay .course02 .tips .tipsabs { top: -30px; left: -10px; width: 75px; padding: 15px 0 20px;}
	.modelcourse #day1.stay .course01 .tips .tipsabs p,
	.modelcourse #day1.stay .course02 .tips .tipsabs p { font-size: 16px;}
	.modelcourse #day1.stay .course03 { }
	.modelcourse #day1.stay .course03 .flex { margin-bottom: 30px;}
	.modelcourse #day1.stay .course03 .left { width: 100%;}
	.modelcourse #day1.stay .course03 .tips .tipsabs { width: 80px; height: auto; top: -25px; right: -35px; position: absolute; margin: 0 20px 0 36px; }
	.modelcourse #day1.stay .course04 { }
	.modelcourse #day1.stay .course04 .flex .left { width: 100%;}
	.modelcourse #day1.stay .course04 h4 {margin-bottom: 36px;}
	.modelcourse #day1.stay .course04 .flex:nth-child(2) .left { width: 100%;}
	.modelcourse #day1.stay .course04 .flex .left:last-child { padding: 20px 0 0; width: 100%; border-top: 2px dotted #c9c9c9; border-left: 0px;}
	.modelcourse #day1.stay .course05 { }
	
	.modelcourse #day2.stay .course01 { }
	.modelcourse #day2.stay .course02 { }
	.modelcourse #day2.stay .course03 { }
	.modelcourse #day2.stay .course03 .flex { margin-bottom: 20px;}
	.modelcourse #day2.stay .course03 .right:last-child { width: 111px; bottom: -20px; left: 0;}
	.modelcourse #day2.stay .imgless .main { line-height: 1.77;}
	.modelcourse #day2.stay .imgless { margin-bottom: 30px;}
	.modelcourse #day2.stay .imgless div { margin: 0 0 20px ;}
	.modelcourse #day2.stay .imgless p { }
	.modelcourse #day2.stay .imgless .time { font-size: 20px; margin-bottom: 12px;}
	.modelcourse #day2.stay .tips { padding: 25px ;}
		
	.modelcourse .slider .slick-dots {bottom: -24px;}
	.modelcourse .slider .slick-list.slick-list-img{margin: 0 10px;}
	.modelcourse .slider .slick-dots li { width: 9px; height: 9px; margin: 0 5px;}
	 /*-------------- other --------------*/
	
	#other { margin-bottom: 50px; padding: 50px 0 0;}
	#other .other { width: 100%;}
	#other h3 { font-size: 20px; margin-bottom: 35px;}
	#other h3 span { font-size: 35px; margin-top: 24px; line-height: 1.29;}
	#other h3 img {  margin: 20px auto 0; width: 45%;}

	#other .reco { margin-bottom: 50px;}
	#other .reco h4 { margin-bottom: 28px;}
	#other .reco h4 img {  height: auto; margin: 0 20px;}
	#other .reco h4 img:nth-child(1){width: 80px;}
	#other .reco h4 img:nth-child(2){width: 45px;}
	#other .reco h4 span .rec { display: block; margin: 0 auto 19px;}

	#other .reco h4:before,
	#other .reco h4:after { width: 30%;}
	#other .reco h5 { font-size: 20px; margin-bottom: 20px; line-height: 1.5;}
	#other .reco p { font-size: 13px; line-height: 1.769; margin-bottom: 30px; text-align: left;}
	#other .reco img { width: 100%; height: auto;}	

	#other .reco .course { margin-bottom: 30px; padding-bottom: 30px; border-bottom: 2px dotted #c9c9c9;}
	#other .reco .course:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: 0px;}
	#other .reco .course .title { width: 100%; line-height: 30px; font-size: 14px; text-align: center; margin-bottom: 25px; padding: 2px 0 3px;}
	
	#other .reco .course .sauna { width: 100%; padding: 19px 13px; margin-top: 25px; }
	#other .reco .course .sauna h6 { font-size: 14px; margin-bottom: 12px;}
	#other .reco .course .sauna h6:before {  width: 3px; height: 15px; margin-right: 12px; vertical-align: -3px;}
	#other .reco .course .sauna p { font-size: 12px; line-height: 1.75; margin-bottom:0px; }
	#other .reco .course .sauna p span{	margin-left: 12px; text-indent: -1.0em; line-height: 1.84; display: block;}
	
}
