@charset "UTF-8";
html{
	scroll-behavior: smooth;
	scroll-padding: 20px;
}
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:192px;
  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{
  width:192px;
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  left:4%;
}
.menu_wrapper{
	display:flex;
	align-items: center;
	gap:25px;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.menu{
	list-style: none;
	padding-inline-start:0px;
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-between;
	margin:0;
	gap:30px;
}
.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:black;
}
.ge-reservation{
	display:block;
	background-color: #4c510c;
	color:white;
	font-size:18px;
	padding:7px 0;
	width:148px;
	text-align: center;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right:3%;
}
/* 共通 */
.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-img{
	position: relative;
}
.top-img h1{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size:38px;
	font-weight:500;
	color: white;
}
.top-line{
	display:flex;
	flex-direction: column;
	align-items: center;
	gap:30px;
	position:absolute;
	right:0;
	bottom:0;
}
.top-line p{
	font-size:16px;
	color:white;
	transform: rotate(90deg);
}
.top-line div{
	height: 78px;
    width: 1px;
    background-color:white;
	margin:0 3px 0 0;
}
.concept{
	padding:100px 0 220px 0;
	position: relative;
}
.concept-line{
	display:flex;
	align-items: end;
	gap:30px;
	position:absolute;
	right:30px;
	top:0;
}
.concept-line p{
	font-size:16px;
	color:black;
	transform: rotate(90deg);
	padding:0 0 40px 0;
}
.concept-line div{
	height: 178px;
    width: 1px;
    background-color:black;
	margin:0 3px 0 0;
}
.concept h2{
	font-size:45px;
	font-weight:500;
}
.concept-txt{
	display:flex;
	justify-content: space-between;
	margin-top:95px;
}
.cocnept-line{
    height: 1px;
	width:53px;
    background-color: #000;
}
.concept-txt p{
	writing-mode: vertical-rl;
	font-size:20px;
	line-height: 1.8;
}
.ge-content-list{
	display:flex;
	flex-direction: column;
	gap:150px;
}
.ge-content-detail{
	display:flex;
	justify-content: space-between;
	gap:100px;
}
.row{
	flex-direction: row-reverse;
}
.ge-content-detail-img{
	margin-left: calc(50% - 50vw);
	position: relative;
}
.row .ge-content-detail-img{
	margin-left:auto;
	margin-right: calc(50.65% - 50vw);
}
.slider{
	width:80%;
}
.slider img{
	display:block;
	width:100%;
}
.prev-arrow{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left:20px;
	z-index: 1;
	width:30px !important;
}
.next-arrow{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	right:20px;
	z-index: 1;
	width:30px !important;
}
.ge-content-detail-txt{
	display:flex;
	flex-direction: column;
	justify-content: space-between;
}
.ge-content-detail-txt-top{
	display:flex;
	flex-direction: row-reverse;
	gap:24px;
}
.ge-content-detail-txt-top h3{
	writing-mode: vertical-rl;
	font-size:54px;
	letter-spacing: -0.02em;
	font-weight:500;
	position: relative;
	top:-7px;
}
.gcd-line{
	height:78px;
	width:1px;
    background-color: #000;
}
.ge-content-detail-txt-top p{
	writing-mode: vertical-rl;
	font-size:18px;
	transform: rotate(0deg);
}
.ge-content-detail-txt-bottom{
	height:320px;
	display:flex;
	flex-direction: row-reverse;
	gap:25px;
}
.ge-content-detail-txt-bottom h4{
	writing-mode: vertical-rl;
	font-size:25px;
	letter-spacing: -0.02em;
	font-weight:500;
	text-align: justify;
}
.ge-content-detail-txt-bottom p{
	writing-mode: vertical-rl;
	font-size:18px;
	letter-spacing: -0.02em;
	text-align: justify;
	line-height: 1.8;
}
.ge-news{
	margin-top:250px;
}
.ge-news-content{
	display:flex;
	justify-content: space-between;
	gap:150px;
}
.ge-news-list-content{
	display:flex;
	flex-direction: column;
	gap:35px;
}
.ge-news-list-content a{
	display:flex;
	flex-direction: column;
	gap:16px;
	padding:0 0 23px 0;
	border-bottom:1px solid black;
	color:black;
}
.ge-news-list-content a span{
	font-size:18px;
}
.ge-news-list-content a .top-news-title{
	font-size:21px;
}
.ge-news-list-content a .top-news-read{
	font-size:17px;
}
.news-all{
	margin-top:40px;
	color:black;
	justify-content: flex-end;
	align-items: center;
	display:flex;
	gap:15px;
}
.na-img{
	width:13px;
}
.na-img img{
	vertical-align: middle;
}
.ge-access-info{
	margin-top:160px;
	padding:110px 0 0 0;
	overflow: hidden;
}
.gai-div{
	display:flex;
	gap:150px;
}
.ge-access-info-title{
	display:flex;
	justify-content: space-between;
	align-items: baseline;
}
.ge-access-info-title h2{
	font-size:44px;
	font-weight:500;
	color: #002742;
}
.ge-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;
}
.ge-access-info-content{
	background-color: #cccccc;
	height:600px;
    margin-right: calc(50.75% - 50vw);
	display:flex;
	flex-direction: column;
}
.ge-access-info-content>div{
	border:solid 1px white;
	margin-right: -1px;
	position: relative;
	height:160px;
}
.ge-access-info-content>div p{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left:55px;
	font-size:28px;
	color:white;
}
.gaiw-ca{
	display:flex;
	justify-content: center;
	border:1px solid black;
	color:black;
	gap:15px;
	margin-top:65px;
	padding:18px 0;
	font-size:22px;
}
.gaiw-ca span{
	width:14px;
}
.gaiw-ca span img{
	vertical-align: middle;
}
.ge-access-map{
	margin-top:170px;
}
.ge-access-map-info-back{
	background-color: black;
	text-align: center;
	width:246px;
	padding:10px 0 20px;
	margin-bottom:-170px;
	position: relative;
	z-index: 1;
}
.ge-access-map-info-back h3{
	color:white;
	font-size:36px;
	font-weight:500;
	margin:0 0 15px 0;
}
.ge-access-map-info-back h3 span{
	font-size:18px;
}
.ge-access-map-info-back p{
	color:white;
	font-size:14px;
	font-weight:400;
	line-height: 1.6;
}
footer{
	background-color: #4c510c;
	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 p{
	font-size:20px;
	margin-bottom:2px;
	font-weight:400;
}
.footer-top-column a{
	font-size:17px;
	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;
}
}