@charset "utf-8";

/*----------------------------------------------------
 common　ページ共通　ここから
---------------------------------------------------- */

/* .montserrat {
  font-family: "Montserrat", sans-serif;
}
.noto-sans-jp {
  font-family: "Noto Sans JP", sans-serif;
}
.noto-serif-jp {
  font-family: "Noto Serif JP", serif;
} */


* {
	box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
}
a {
	transition: opacity 0.3s ease-out;
}
a:hover {
	opacity: 0.8;
}
figure {
	width: fit-content;
}
.inner {
	width: min(1500px, 96%);
	margin-inline: auto;
	position: relative;
}
.f_serif {
	font-family: "游明朝体", "Yu Mincho", YuMincho, "Noto Serif JP","Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", Serif;;
}
.f_en {
	font-family: 'Montserrat', 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ＭＳ Ｐゴシック', sans-serif;
}
.text {
	letter-spacing: 0.08em;
	line-height: 2;
}
.tac {
	text-align: center;
}
.logo {
	width: min(510px,100%);
}
/* .swiper-wrapper {
	height: 100svh;
} */

/*スクロールダウン全体の場所*/
.scrolldown1{
    /*描画位置※位置は適宜調整してください*/
  position:absolute;
  left:50%;
  bottom:10px;
    /*全体の高さ*/
  height:50px;
  z-index: 10;
}

/*Scrollテキストの描写*/
.scrolldown1 span{
    /*描画位置*/
  position: absolute;
  left: -50%;
  top: clamp(-40px,-3vw,-15px);
  transform: translateX(-50%);
    /*テキストの形状*/
  color: #eee;
  font-size: clamp(0.7rem,2vw,1.4em);
  letter-spacing: 0.05em;
  text-shadow: #333 0px 0px 4px,#333 0px 0px 4px,#333 0px 0px 4px,#333 0px 0px 8px,#333 0px 0px 8px,#333 0px 0px 8px;
}

/* 線の描写 */
.scrolldown1::after{
  content: "";
    /*描画位置*/
  position: absolute;
  top: 0;
    /*線の形状*/
  width: 1px;
  height: 30px;
  background: #eee;
    /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 1.4s ease-in-out infinite;
  opacity:0;
  box-shadow: 4px 4px 4px #000,4px 4px 8px #000;
}

/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove{
  0%{
    height:0;
    top:0;
    opacity: 0;
  }
  30%{
    height:30px;
    opacity: 1;
  }
  100%{
    height:0;
    top:50px;
    opacity: 0;
  }
}
.hover-effect {
	overflow: hidden;
}
.hover-effect img{
    transform: scale(1.05);
    filter: brightness(.8);
}
.border-bottom {
	padding-bottom: 1px;
	border-bottom: 1px solid #000;
}
/*************************************************

 wrapper

*************************************************/
#wrapper {
	color: #000;
	font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, '游ゴシック', 'Yu Gothic', '游ゴシック体', 'YuGothic', 'ＭＳ Ｐゴシック', sans-serif;
	/* font-family: "游明朝体", "Yu Mincho", YuMincho, "Noto Serif JP",  "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", Serif; */
	font-size: 16px;
	line-height: 1.7;
	text-align: left;
}
.wrap {
	margin-right: auto;
	margin-left: auto;
	padding-right: 15px;
	padding-left: 15px;
}

/* btn
------------------------- */
/* .btn {} */
.btn__inner {
	margin-top: 60px;
}
.btn__link {
	width: fit-content;
	padding-inline: min(1em, 2vw);
	line-height: 3;
	color: #f1ebe8;
	text-align: center;	
	background-color: #000;
	border-radius: 8px;
	border: 1px solid #fff;
	
	display: flex;
	align-items: center;
	gap: 8px;
}
.btn__link--special {
	background-color: #b06c3e;
	border-color: #b06c3e;
}
.btn img {
	width: 1em;
	height: auto;
	transition: transform 0.3s ease-out;
	transform: translateX(0%);
}
.btn__link:hover img{
	transform: translateX(20%);
}

/* header
----------------------------------------- */
.header {
	width: 100%;
	/* height: 106px; */
	display: flex;
	justify-content: center;
	align-items: center;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 1000;
	padding-block: 1em;
	
	transition: all 0.4s;
}
/* .header .logo img {} */
.header__btns {
	display: flex;
	align-items: center;
}
.header__hmenu {
	width: 56px;
	height: 56px;
	background-color: unset;
    border: none;
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: relative;
	z-index: 501;
	padding-top: 20px;
	cursor: pointer;
	filter: drop-shadow(0 0 4px #000000aa);
}
.hmenu__border {
	font-size: 16px;
	position: relative;
	display: block;
	background-color: #fff;
	width: 2em;
	height: 3px;
	margin-bottom: 1em;
	transition: all 0.3s ease-out;
}
.hmenu__border::before,
.hmenu__border::after {
	display: block;
	content: '';
	background-color: #fff;
	width: 2em;
	height: 3px;
	transition: all 0.3s ease-out;
}
.hmenu__border::before {
	position: absolute;
	top: -0.6em;
}
.hmenu__border::after {
	position: absolute;
	top: 0.6em;
}

/* .header__hmenu.is-open {} */
.header__hmenu.is-open span{
	background-color: unset;
}
.header__hmenu.is-open span::before {
	top: 0em;
	transform: rotate(45deg);
}
.header__hmenu.is-open span::after {
	top: 0;
	transform: rotate(-45deg);
}
.header__hmenu.is-open .hmenu__text {
	display: none;
}
.hmenu__text2 {
	display: none;
}
.header__hmenu.is-open .hmenu__text2 {
	display: block;
}

/* gnav
------------------------------------------ */
.gnav {
	font-size: min(22px, 1vw);
	letter-spacing: 0.05em;
	width: 100%;
	margin-right: 40px;
	text-transform: uppercase;
}
.gnav__list {
	display: flex;
	justify-content: flex-end;
	gap: 10px;
}
.footer .gnav__list {
	justify-content: center;
	column-gap: 60px;
	flex-wrap: wrap;
	max-width: 600px;
    margin-inline: auto;
}
.gnav__item {
	/* line-height: 3; */
	color: #f1ebe8;
	text-align: center;
	/* width: min(200px,100%); */
	position: relative;
	/* mix-blend-mode: difference; */
	display: flex;
	justify-content: center;
	place-items: center;
}
.footer .gnav__item {
	text-align: left;
	line-height: 2;
}
.gnav__item--border {
	border: 1px solid #fff;
	border-radius: 4px;
}
.gnav__link,
.gnav__sub-link {
	display: flex;
	/* justify-content: center; */
	align-items: center;
	gap: 1em;
	width: 100%;
	/* height: 100%; */
	padding-inline: 1em;
	color: inherit;
	word-break: keep-all;
	cursor: pointer;
}
.header .gnav__link {
	position: relative;
}
/* .header .gnav__link::before {
	display: block;
	content: '';
	width: 100%;
	height: 4px;
	border-radius: 0 0 4px 4px;
	background-color: #fff;
	transition: all 0.3s ease-out;
	position: absolute;
	bottom: 0;
	left: 0;
	opacity: 0;
}
.header .gnav__link.is-active::before, */
.header .gnav__link:hover::before {
	opacity: 1;
}
.footer .gnav__link,
.footer .gnav__sub-link {
	display: inline;
	height: auto;
}
.gnav__sub {
	display: none;
	position: absolute;
	top: 100%; /* 親リンクの下に配置 */
	left: 50%;
	transform: translateX(-50%);
	z-index: 10; /* サブメニューが他の要素の下に隠れないように */
	width: min(200px,100%);
}
.footer .gnav__sub {
	display: block;
	position: static;
	transform: unset;
	width: fit-content;
}
.gnav__sub-list {
	border-radius: 4px;
}
.gnav__sub-list-item + .gnav__sub-list-item {
	border-top: 1px solid #fff;
}
.footer .gnav__sub-list-item + .gnav__sub-list-item {
	border-top: 0px;
}
.footer .gnav__sub-list-item {
	display: flex;
	align-items: center;
	gap: 0.5em;
}
.footer .gnav__sub-list-item::before {
	display: block;
	content: '';
	width: 1em;
	height: 1px;
	background-color: #f1ebe8;
}
.gnav__sub-link {
	background-color: rgba(40, 46, 103, 0.8);
	transition: opacity 0.3s ease-out;
}
.footer .gnav__sub-link {
	background-color: unset;
}
.gnav__sub-link:hover {
	opacity: 0.8;
}

/* footer
------------------- */
.footer {
	color: #f1ebe8;
	background-color: #444;
	padding-top: 64px;
	padding-bottom: 64px;
	text-align: center;
}
.footer__inner {
	width: min(960px,96%);
	margin-inline: auto;
}
.footer .logo {
	width: min(340px, 70%);
	height: auto;
}
.footer__contents {
	display: flex;
}
.footer__contents2 {
    margin-top: 60px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.footer__link-list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
}
.footer__link-item {
	display: contents;
}
.sns-list {
	width: fit-content;
	margin-top: 32px;
	display: flex;
	justify-content: center;
	gap: 20px;
}
.sns-list--special {
	justify-content: flex-start;
}
.sns-list__item {
	width: min(48px,100%);
}
.footer__copylight {
	margin-top: 60px;
	font-size: 16px;
}

.footer_cp_label {
    margin-bottom: 0.2rem;
    font-size: 1rem;
    font-weight: 500;
}
.footer_cp_logo {
	width: min(150px, 100%);
}
/*----------------------------------------------------
 common　ページ共通　ここまで
---------------------------------------------------- */

@media screen and (min-width: 1025px) {
    .header .gnav {
        display: block !important;
    }
	.header.is-on {
	background-color: rgb(0, 0, 0, 0.6);
}
}
@media screen and (max-width: 1024px) {
	.header {
		justify-content: space-between;
		align-items: center;
	}
	.header .logo {
		width: min(330px,50%);
		position: relative;
		z-index: 501;
	}
	.gnav {
		font-size: min(26px,5vw);
	}
	.header .gnav {
		display: none;
		margin-top: 0;
		position: fixed;
		z-index: 500;
		top: 0;
		left: 0;
		width: 100%;
		height: 100svh;
		background-color: rgba(0, 0, 0, 0.8);
		margin-right: 0;
	}
	.header .gnav .btn {
		font-size: 12px;
	}
	.header .gnav__list {
		/* background-color: #fff; */
		height: auto;
		max-height: 80svh;
		width: 100%;
		overflow-y: auto;

		/* display: block; */
		padding: 20px;
		flex-direction: column;

		position: absolute;
		top: 70px;
		left: 50%;
		transform: translateX(-50%);
	}
	.header .gnav__item {
		line-height: 2;
		flex-direction: column;
		justify-content: flex-start;
		align-items: flex-start;
		width: 100%;
	}
	.header .gnav__sub {
		display: block;
		position: static;
		transform: unset;
		width: 100%;
	}
	.header .gnav__sub-link {
		background-color: unset;
	}
	.header .gnav__sub-list-item {
		display: flex;
		align-items: center;
		gap: 0.5em;
		padding-left: 1em;
	}
	.header .gnav__sub-list-item::before {
		display: block;
		content: '';
		width: 1em;
		height: 1px;
		background-color: #111;
	}
	.header .gnav__item--border {
		border: none;
		position: relative;
		padding-top: 10vw;
	}
	.header .gnav__item--border::before {
		display: block;
		content: '';
		width: 3em;
		height: 1px;
		background-color: #111;
		position: absolute;
		top: 5vw;
		left: 5vw;
	}
	.header .header__reservation {
		line-height: 40px;
		font-size: 12px;
		border-radius: 4px;
	}
	.header .gnav__link.is-active::before,
	.header .gnav__link:hover::before {
		opacity: 0;
	}
	.header .pcView {
		display: none !important;
	}
	.header .spView {
		display: inline !important;
	}
}


/*------------------------------------------
 topページ　ここから
------------------------------------------ */
.top-bg {
	background-color: #e7e9e7;
}
/* top-section
------------------------------------------ */
.top-section {
	padding-top: 100px;
	padding-bottom: 100px;
	overflow: hidden;
}
.top-section-bg {
	position: relative;
	z-index: 0;
}
.top-section-bg::before {
	display: block;
	content: '';
	background-image: url('../img/top/top-section-bg.png');
	background-repeat: repeat-x;
	background-size: contain;
	background-position: 0% 100%;
	width: 110%;
	height: 96%;
	position: absolute;
	top: 20%;
	left: unset;
	right: 10%;
	z-index: -1;
}
.top-section-bg--special {
	padding-block: min(100px, 10vw);
}
.top-section-bg--special::before {
	background-image: url('../img/top/top-section-bg.png');
	background-position: 0% 100%;
	height: 100%;
    top: 0;
    left: unset;
    right: 10%;
}
.top-section:nth-of-type(even) .top-section-bg::before {
	left: 10%;
	right: unset;
}
.top-section__inner {
	width: min(1010px, 96%);
	display: flex;
	gap: 20px;
	justify-content: space-between;
}
.top-section:nth-of-type(even) .top-section__inner {
	flex-direction: row-reverse;
}

.top-section__inner--column {
	flex-direction: column !important;
	align-items: center;
}

.top-section__header {
	width: fit-content;
}
.top-section__header--special {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.top-section__title {
	font-size: clamp(30px, 4vw, 50px);
	line-height: 1.1;
	font-weight: bold;
	letter-spacing: 0.03em;
	margin-right: 1em;
	color: #5f6d5b;
	text-transform: capitalize;
}
.top-section__title::before {
	display: block;
	content: '';
	width: 2em;
	height: 2px;
	background-color: #5f6d5b;
	margin-bottom: 20px;
}


.top-section__sub-title {
	display: block;
	font-size: clamp(20px, 2vw, 34px);
	font-weight: bold;
	margin-bottom: 20px;
}
/* .top-section__contents {} */
.top-section__contents--special {
	border-left: 1px solid #ccc;
}
/* .top-section__text {} */
.top-section__img {
	overflow: hidden;
	margin-top: 30px;
}
.top-section__img img {
	transition: all 0.3s ease;
}

/* top-mv
------------------------------------------ */
.top-mv {
	width: 100%;
	overflow: hidden;
	/* height: 100svh; */
}
.top-mv__img img {
	width: 100%;
	height: 100svh;
	object-fit: cover;
}

.top-mv figure {
	position: relative;
	width: 100%;
}
.top-mv figcaption {
	position: absolute;
	bottom: 0;
	right: 0;
	padding: 0 10px;
	color: #fff;
	font-size: 10px;
	background-color: rgba(0, 0, 0, 0.8);
	line-height: 1.8;
}

.top-mv__texts {
	position: absolute;
	top: 50%;
	left: 5%;
	transform: translateY(-50%);
	color: #fff;
	text-align: center;
	z-index: 1;
	background-color: rgba(92, 104, 87, 0.9);
	padding: min(40px, 3vw);
}
.top-mv__text01 {
	font-size: clamp(20px, 3vw, 40px);
	font-weight: 600;
	letter-spacing: 0.03em;
	border-bottom: 2px solid #fff;
	padding-bottom: min(20px, 2vw);
	margin-bottom: min(20px, 2vw);
}
.top-mv__text02 {
	font-size: clamp(16px, 2vw, 24px);
	line-height: 2;
}
.top-mv__btns {
	display: flex;
	justify-content: center;
	gap: min(20px, 2vw);
	
	position: absolute;
	bottom: 5%;
	right: 5%;
	z-index: 1;
}
	

/* top-concept
----------------- */
.top-concept {
	padding-block: 0px !important;
}

/* top-gallery
----------------- */

.top-gallery {
	background-color: #5f6d5b;
	color: #fff;
	position: relative;
	padding-bottom: 200px;
	margin-top: min(100px, 10vw);
}
.top-gallery .top-section__title {
	color: #fff;
}
.top-gallery .top-section__title::before {
	background-color: #fff;
}
.top-gallery .top-section__contents {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: min(40px,4vw);
}
.top-gallery .top-section__sub-title {
	margin-bottom: 0;
}
.top-gallery .swiper-container {
	margin-block: min(60px, 6vw);
	margin-bottom: min(80px, 10vw);
}
.top-gallery__swiper {
	width: min(1010px, 96%);
	margin-inline: auto;
	position: relative;
}
.top-gallery .swiper-slide figure {
	margin-inline: 20px;
}
.top-gallery .swiper-button-next,
.top-gallery  .swiper-button-prev {
	color: #fff;
}
.top-gallery .swiper-button-next {
	right: -10px;
}
.top-gallery .swiper-button-prev {
	left: -10px;
}
.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
	bottom: -30px;
}
.top-gallery .swiper-pagination-bullet-active {
	background: #fff;
}
.top-gallery .swiper-button-next:after,
.top-gallery .swiper-button-prev:after {
	font-size: min(40px, 5vw);
}
.top-gallery::after {
	display: block;
	content: '';
	width: 100%;
	height: 284px;
	/* aspect-ratio: 3846 /284; */
	/* height: 100px; */
	background-image: url('../img/top/top-section-access-bg.png');
	
	background-repeat: repeat-x;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center bottom;
	position: absolute;
	bottom: 0;
}


/* top-news
------------------ */
.top-news__inner {
	display: grid;
	grid-template-columns: 1fr 4fr;
}
.top-news__list {
	margin-left: min(130px,4vw);
}
.top-news__list li + li{
	margin-top: 2em;
}
.top-news__item {
	font-size: 17px;
}
.top-news__text {
	display: flex;
	align-items: flex-start;
	column-gap: min(20px,2vw);
}
.top-news__text a{
  color: initial; /* デフォルト色に戻す */
  text-decoration: underline; 
}

/* top-access
------------------ */
.top-access {
	background-color: #fff;
}
.top-access__inner {
	display: grid;
	grid-template-columns: 1fr 3fr;
}
.top-access .top-section__contents {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: min(40px,4vw);
}
.top-access .top-section__sub-title {
	margin-bottom: 0;
}
.top-access__list {
	display: flex;
	justify-content: center;
	gap: min(40px, 2vw);
	margin-top: 20px;
}
.top-access__item {
	font-size: 16px;
	display: grid;
	grid-template-columns: auto 1fr;
	gap: min(20px, 1vw);
	align-items: flex-start;
}
.top-access__map {
	overflow: hidden;
	aspect-ratio: 1000 /513;
	width: 100%;
	height: auto;
	z-index: 0;
	filter: grayscale(100%);
	position: relative;
}
.top-access__map::after {
	display: block;
	content: '';
	width: 100%;
	height: 100%;
	background-color: #aebc90;
    mix-blend-mode: multiply;
    opacity: 0.1;
	position: absolute;
	top: 0;
	left: 0;
	/* transform: translateY(-50%); */
	z-index: 1;
	pointer-events: none;
}
.top-access__map  iframe{
	aspect-ratio: 1000 /513;
	width: 100%;
	height: auto;
	border: none;
}

/*------------------------------------------
 topページ　ここまで
------------------------------------------ */

@media screen and (max-width:1024px) {
		.top-mv__btns {
		position: fixed;
	}
}
@media screen and (max-width:768px) {
	.inner {
		padding-inline: 15px;
	}
	.top-section {
		padding-top: 30px;
		padding-bottom: 30px;
	}
	.top-mv__texts {
		top: 40%;
		left: 50%;
		transform: translate(-50%, -50%);
		padding: max(10px, 4vw);
		width: max(300px, 80vw);
	}
	.top-mv__text02 {
		line-height: inherit;
	}
	.top-mv__btns {
		font-size: 12px;
	}
	.top-section__inner,
	.top-section:nth-of-type(even) .top-section__inner {
		flex-direction: column;
	}
	.top-section-bg--special::before {
		background-size: 50% 100%;
	}
	.top-gallery .top-section__contents,
	.top-access .top-section__contents {
		flex-direction: column;
	}
	.top-access__list,
	.top-access__item {
		grid-template-columns: 1fr;
	}
	.top-access__list {
		flex-direction: column;
		padding-inline: 25px;
	}
	.footer__contents {
		display: block;
	}
	/* .top-information__item {
		grid-template-columns: 1fr;
	} */
	.top-section__header--special {
		display: contents;
	}
	.top-section__header--special .btn {
		order: 1;
	}
	.top-section__text {
		font-size: 14px;
	}
	.top-section__sub-title--special {
		text-align: left;
	}
	.top-section__contents {
		padding-inline: 10px;
	}
	.top-section__contents--special {
		border: none;
	}
	.footer .gnav {
		margin-right: unset;
	}
	.footer .gnav__list {
		display: grid;
		grid-template-columns: 1fr 1fr 1fr;
		gap: 0;
	}
	.footer .gnav__item {
		text-align: center;
	}
	.footer .gnav__link {
		padding: 0;
	}
	.btn a {
		line-height: 3;
		padding-inline: 2em;
	}
	.btn img {
		width: 18px;
	}
	.btn__inner {
		margin-top: 30px;
	}
	.top-news__list {
		margin-left: 0;
	}
	.header__reservation--special {
		line-height: 3;
		margin-top: 60px;
	}
	.top-information__item {
		font-size: 14px;
        line-height: 1.5;
	}
	.top-news__item {
		font-size: 14px;
	}
}
