@charset "UTF-8";
html{
	scroll-behavior: smooth;
	scroll-padding: 80px;
}
body{
	margin:0;
	padding:0;
	font-family:"Noto Serif JP", serif;
	/* font-feature-settings: "palt" 1, "trad" 1; */
}
a{
	 text-decoration: none;
}
img{
	vertical-align: top;
	width:100%;
}
h1,h2,h3,h4,h5,h6,p{
	margin:0;
}
@media all and (min-width: 1000px) {
.sp{
	display:none;
}
/*headerはここから*/
header{
	width: 100%;
	height:100px;
	transition: .3s;
	position:relative;
	position: absolute;
	top:0;
	z-index: 9999;
}
.is-animation {
   position:fixed;
   background-color: white;
}
.logo{
  overflow: hidden;
  width:140px;
  display: inline-block;
  float:left;
  transition: .3s;
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  left:4%;
}
.logo img{
  width:100%;
}
.logo-img{
	transition: .3s;
}
.is-animation .logo-img {
  content: url("image/logo-b.png");
}
.is-animation .logo{
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  left:4%;
}
.menu_wrapper{
	display:flex;
	align-items: center;
	gap:25px;
	position: absolute;
	right:2%;
	top: 50%;
  	transform: translateY(-50%);
}
.menu{
	list-style: none;
	padding-inline-start:0px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:0;
	gap:15px;
}
.menu li {
	 font-size:14px;
	 margin:0 0 0 0;
	 font-weight: 500;
	 letter-spacing: 1px;
}
.menu li a{
	 color:white;
}
.is-animation .menu li a{
	 color:#002742;
}
.shop-btn{
	width:140px;
}
.shop-btn-img{
	transition: .3s;
}
.is-animation .shop-btn-img {
  content: url("image/shop-btn-b.png");
}
/* 共通 */
.common-width-b{
	max-width:1150px;
	width:90%;
	margin:0 auto;
}
.common-width-m{
	max-width:1024px;
	width:90%;
	margin:0 auto;
}
.common-width-s{
	max-width:840px;
	width:90%;
	margin:0 auto;
}
.common-title-parts{
    display: flex;
    align-items: center;
    gap: 1rem; /* 線と文字の間隔 */
    font-family: serif;
    font-size: 2rem;
    color: #000;
    padding: 2rem;
}
.line {
    flex: 0 0 46px; /* 線の長さを調整 */
    height: 1px;
    background-color: #000;
}
.common-title-parts h3{
	font-size:23px;
	font-weight:400;
	font-family: "Lusitana", serif;
	letter-spacing: 0.075em;
}
.common-title-h2{
	margin-top:70px;
	color:#002742;
	font-size:44px;
	font-weight:400;
	letter-spacing: 0.095em;
}
/* メインはここから */
.top{
	position: relative;
}
.top-info{
	position: absolute;
	bottom:0;
	left:0;
	width:100%;
	background-color: rgba(0, 39, 66, 0.9);
	padding:24px 0;
}
.top-info p{
	font-size:15px;
	color:white;
}
.about{
	background-color: #ccdadd;
	padding:100px 0 110px;
	position: relative;
}
.about-content{
	margin-top:60px;
}
.about-content h4{
	color:#002742;
	font-size:54px;
	font-weight:500;
	letter-spacing: 0.045em;
}
.about-content h2{
	font-size:28px;
	font-weight:400;
	letter-spacing: 0.095em;
	margin:50px 0 40px 0;
}
.about-content p{
	font-size:18px;
	font-weight:400;
	width:600px;
	text-align: justify;
	line-height: 1.9;
	letter-spacing: -0.04em;
}
.about-back{
	width:420px;
	mix-blend-mode: multiply;
	position: absolute;
	right:0;
	bottom:30px;
}
.dcp{
	padding:120px 0;
}
.dcp-read{
	font-size:21px;
	font-weight:400;
	letter-spacing: 0.095em;
	margin-top:40px;
}
.dcp-main-img{
	margin:40px 0 125px 0;
}
.dcp-point-list{
	display:flex;
	flex-direction: column;
	gap:110px;
}
.dcp-point-list-detail h3{
	font-size:39px;
	color:#002742;
	font-weight:400;
	letter-spacing: 0.095em;
}
.dcp-point-list-detail-left::before{
	content: "";
	position: absolute;
	left: 1px; /* 親の左に配置 */
	top: 0;
	bottom: 0;
	width: 1px; /* 線の太さ */
	height:100%;
	background-color: #000; /* 線の色 */
}
.dcp-point-list-detail-left{
	margin-top:65px;
	position: relative;
}
.dcp-point-list-detail-left::after{
	content: "";
	position: absolute;
	left: 0; /* 親の左に配置 */
	top: 0;
	bottom: 0;
	width: 3px; /* 線の太さ */
	height:472px;
	background-color: #000; /* 線の色 */
}
.dcp-left-1{
	display:flex;
	flex-direction: column;
	gap:75px;
	padding:0 0 0 80px;
}
.dcp-point-list-detail-1-content{
	display:flex;
	align-items: center;
}
.dcp-point-list-detail-1-content-img{
	width:515px;
}
.dcp-point-list-detail-1-content-txt{
	max-width:405px;
	right:-90px;
	position: relative;
}
.dcp-point-list-detail-1-content-txt h4{
	font-size:29px;
	font-weight:400;
}
.dcp-line {
    height: 1px;
	width:50px;
    background-color: #000;
	margin:50px 0;
}
.dcp-point-list-detail-1-content-txt p{
	text-align: justify;
	font-size:18px;
	font-weight:400;
	line-height: 1.8;
}
.dcp-point-2-flex{
	display:flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	padding:0 0 0 80px;
}
.dcp-point-2-img{
	width: 40vw;
	height:905px; 
    margin-right: calc(50% - 50vw);
	position: relative;
	right:48px;
}
.dcp-point-2-img img{
	height:100%;
	object-fit: cover;
}
.dcp-point-2-txt{
	display:flex;
	flex-direction: column;
	gap:50px;
}
.dcp-point-2-txt>div{
	display:flex;
	align-items: start;
	gap:35px;
}
.dcp-point-2-txt .no{
	font-size:50px;
	line-height: 1;
	padding:0 0 15px 0;
	border-bottom:2px solid;
}
.dcp-point-2-txt-detail{
	width:360px;
}
.dcp-point-2-txt-detail h4{
	font-size:29px;
	font-weight:400;
}
.dcp-point-2-txt-detail h5{
	font-size:22px;
	font-weight:500;
	color: #002742;
	margin:30px 0 22px;
}
.dcp-point-2-txt-detail p{
	font-size:18px;
	font-weight:400;
	letter-spacing: 0.08em;
	list-style: 1.8;
}
.dcp-left-3{
	padding:0 0 0 80px;
}
.dcp-3-read{
	font-size:29px;
	letter-spacing: 0.075em;
}
.dcp-map{
	margin:80px 0;
}
.dcp-left-3 h5{
	font-size:21px;
	border:1px solid black;
	border-radius: 3px;
	display:inline-block;
	padding:7px 45px;
}
.dcp-info-list{
	margin-top:60px;
	display:flex;
	flex-direction: column;
	gap:35px;
}
.dcp-info-list-detail{
	display:flex;
	gap:18px;
}
.dcp-info-list-detail-no{
	display:flex;
	align-items: center;
	gap:30px;
	width:305px;
}
.dcp-info-list-detail-txt{
	display:flex;
	gap:20px;
	margin-top:30px;
	width:70%;
}
.dcp-info-list-detail-no p:nth-child(1){
	font-size:33px;
}
.dcp-info-list-detail-no p:nth-child(2){
	font-size:24px;
}
.dcp-info-list-detail-txt p:nth-child(2){
	font-size:19px;
}
.dcp-caution{
	margin-top:56px;
	padding:34px;
	background-color: rgba(204, 218, 221, 0.3);
}
.dcp-caution-content {
	display:flex;
	justify-content: space-between;
}
.dcp-caution-content p:nth-child(1){
	font-size:21px;
}
.dcp-caution-content p:nth-child(2){
	font-size:17px;
	line-height: 1.7;
}
.three-spot-list{
	display:flex;
	flex-direction: column;
	gap:160px;
}
.three-spot-list-detail-sub-title{
	display:flex;
	align-items: center;
	gap:16px;
}
.tsl-line {
    flex: 0 0 46px; /* 線の長さを調整 */
    height: 1px;
    background-color: #000;
}
.tsl-title{
	margin-top:57px;
}
.tsl-title h2{
	font-size:44px;
	font-weight:500;
	letter-spacing: 0.095em;
	margin-bottom:40px;
	color:#002742;
}
.tsl-title p{
	font-size:21px;
	letter-spacing: 0.08em;
	line-height: 1.6;
}
.tsl-img{
	margin-top:50px;
}
.spa-price{
	margin-top:140px;
}
.spa-price-content{
	margin-top:40px;
}
.spa-price-content h3{
	font-size:44px;
	font-weight:500;
	color: #002742;
	letter-spacing: 0.095em;
}
.spa-price-content-group-detail{
	border-top:1px solid black;
	padding:38px 35px;
}
.spa-price-content-group-detail:last-child{
	border-bottom:1px solid black;
}
.spa-price-content-group{
	margin-top:80px;
}
.spa-price-content-group-detail-info{
	display:flex;
	flex-direction: column;
	gap:20px;
}
.spa-price-content-group-detail-info>div{
	display:flex;
	gap:80px;
}
.spa-price-content-group-detail-info div p{
	font-size:21px;
	line-height: 1.8;
}
.spa-price-content-group-detail-info div p .ca{
	font-size:19px;
}
.spc-title{
	width:130px;
	display: block;
	text-align: justify;
	text-align-last: justify;
	text-justify: inter-ideograph;
	position: relative;
}
.spc-title::after{
	content: ":";
	position: absolute;
	right:-30px;
	top:-1px;
}
.spc-tel-flex{
	align-items: center;
}
.spc-tel{
	font-size:29px !important;
}
.spa-rental{
	padding-right:0 !important;
}
.rental-flex{
	display:flex;
	justify-content: space-between;
}
.rental-block{
	width:650px;
}
.rental-read{
	font-size:19px !important;
}
.rental-block-table{
	margin-top:20px;
	display:grid;
	grid-template-columns: repeat(2, 1fr);
}
.rental-block-table div{
	border:solid 1px black;
	padding:10px 15px;
	margin-bottom: -1px;
	margin-right: -1px;
}
.rental-block-table p{
	font-size:18px !important;
	display:flex;
	justify-content: space-between;
}
.spa-info-content{
	gap:50px;
}
.spa-info-content>p{
	width:88px;
}
.spa-info-content ul{
	padding-left:25px;
}
.spa-info-content li{
	font-size:18px;
	list-style: none;
	margin:10px 0;
	position: relative;
}
.spa-info-content ul>li::before{
	content: "○";
	position:absolute;
	left:-25px;
}
.spa-info-content .no1::before{
	content: "①";
	position:absolute;
	left:-25px;
}
.spa-info-content .no2::before{
	content: "②";
	position:absolute;
	left:-25px;
}
.spa-access-info{
	margin-top:160px;
	background-color: rgba(0, 39, 66, 0.2);
	padding:110px 0 0 0;
	overflow: hidden;
}
.spa-access-info-title{
	display:flex;
	justify-content: space-between;
	align-items: baseline;
}
.spa-access-info-title h2{
	font-size:44px;
	font-weight:500;
	color: #002742;
}
.spa-access-info-title p{
	display:flex;
	align-items: center;
	font-size:18px;
	font-weight:300;
}
.arrow-img{
	width:14px;
	margin:0 0 0 10px;
}
.arrow-img img{
	vertical-align: middle;
}
.spa-access-info-width{
	margin-top:85px;
}
.spa-access-info-content{
	background-color: #cccccc;
	height:600px;
    margin-right: calc(50.75% - 50vw);
	display:grid;
	grid-template-columns: repeat(5, 1fr);
}
.spa-access-info-content>div{
	border:solid 1px white;
	margin-right: -1px;
	position: relative;
}
.spa-access-info-content>div p{
	writing-mode: vertical-rl;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom:0;
	height:285px;
	font-size:30px;
	color:white;
}
.spa-access-map{
	margin-top:170px;
}
.spa-access-map-info-back{
	background-color: black;
	text-align: center;
	width:246px;
	padding:10px 0 20px;
	margin-bottom:-170px;
	position: relative;
	z-index: 1;
}
.spa-access-map-info-back h3{
	color:white;
	font-size:36px;
	font-weight:500;
	margin:0 0 15px 0;
}
.spa-access-map-info-back h3 span{
	font-size:18px;
}
.spa-access-map-info-back p{
	color:white;
	font-size:14px;
	font-weight:400;
	line-height: 1.6;
}


footer{
	background-color: #002742;
	padding:100px 0 14px 0;
}
small{
	font-size:14px;
	color:white;
}
small p{
	text-align: center;
}
.footer-top{
	display:flex;
	justify-content: space-between;
}
.footer-top>div{
	padding:0 30px;
	border-right:1px solid white;
	border-left:1px solid white;
}
.footer-top>div:nth-child(1){
	padding:0 30px 0 0;
	border:none;
}
.footer-top>div:nth-child(3){
	border-left:none;
}
.footer-top>div:nth-child(4){
	padding:0 0 0 30px;
	border:none;
}
.footer-top p{
	color:white;
}
.footer-top a{
	color:white;
}
.f-title{
	font-size:23px;
}
.footer-top-column{
	display:flex;
	flex-direction: column;
	gap:7px;
}
.footer-top-column a{
	font-size:17px;
	font-weight:400;
}
.footer-top-column p>a{
	font-size:20px;
	margin-bottom:2px;
	font-weight:400;
}
.ft-flex{
	display:flex;
	gap:25px;
}
.ft-flex-title{
	font-size:23px;
}
.ft-flex-column{
	display:flex;
	flex-direction: column;
	gap:30px;
}
.footer-bottom{
	border-top:1px solid white;
	margin-top:100px;
	margin-bottom:40px;
	padding:40px 0 0 0;
}
.footer-bottom-content{
	display:flex;
	justify-content: space-between;
	align-items: center;
}
.fb-line {
    height: 120px;
	width:1px;
    background-color:white;
}
.footer-bottom a{
	color:white;
}
.footer-bottom p{
	color:white;
}
.fb-tel-title{
	font-size:25px;
}
.fb-tel{
	text-align: center;
}
.fb-tel a{
	font-size:28px;
}
.fb-tel a span{
	font-size:22px;
}
.fb-tel-info{
	font-size:14px;
}
.fb-plan div{
	display:flex;
	flex-direction: column;
	text-align: center;
}
.fb-plan p{
	font-size:25px;
}
.fb-plan div a{
	display:flex;
	text-align: center;
	gap:10px;
	font-size:18px;
}
.fb-arrow img{
	width:6px;
	vertical-align: middle;
}
.fb-l-title{
	font-size:25px;
}


}