@charset "UTF-8";

/* base */

/* Tools */

.text-left {
	text-align: left;
}

.text-center {
	text-align: center;
}

.text-right {
	text-align: right;
}

.d-block {
	display: block;
}

.d-inline-block {
	display: inline-block;
}

.hidden {
	display: none !important;
}

.clearfix::before,
.clearfix::after {
	content: "";
	display: table;
}

.clearfix::after {
	clear: both;
}

.clear {
	clear: both;
}

/* show only  SP/PC
-------------------------------*/

.sp-only {
	display: none !important;
}

.sp-only-2 {
	display: none !important;
}

.pc-only {
	display: block !important;
}

.pc-only-2 {
	display: inline-block !important;
}

/* font
-------------------------------*/

.fw-700 {
	font-weight: 700;
}

/* margin
-------------------------------*/

/* padding
-------------------------------*/

/* gap
-------------------------------*/

/* grid
-------------------------------*/

.grid-1col > *,
.grid-2col > *,
.grid-3col > *,
.grid-4col > * {
	min-width: 0;
}

.grid-1col {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.grid-2col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.grid-3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.grid-4col {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

/* Layout */

body:has(.l-wrapper.is-menu-opend) {
	overflow: hidden;
}

#skiptocontent a {
	background: #008458;
	color: #FFF;
}

.l-wrapper {
	position: relative;
	width: 100%;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1.8rem;
	color: #3B3838;
}

.l-wrapper::after {
	content: "";
	opacity: 0;
	pointer-events: none;
	z-index: 3000;
	background: rgba(0, 0, 0, 0.4);
	position: fixed;
	top: 0;
	left: 0;
	-webkit-transition: 0.3s;
	transition: 0.3s;
	width: 100%;
	height: 100%;
}

.l-wrapper.is-fixed {
	position: fixed;
}

.l-wrapper.is-menu-opend::after {
	opacity: 1;
}

.l-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
	padding: 30px;
	z-index: 5000;
}

.l-footer {
	position: relative;
	background: url(../img/bg_footer.jpg) no-repeat center center/cover;
}

.l-footer::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(59, 56, 56, 0.7);
	z-index: 0;
	mix-blend-mode: multiply;
}

.l-navi {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
	max-width: 490px;
	max-height: 100%;
	background: #FFD900;
	font-size: 1.8rem;
	color: #FFF;
	z-index: 3000;
	overflow-y: auto;
}

.l-navi__inner {
	padding: 10rem 60px 6rem;
	/* height: auto; */
  height: 100%;
}

.l-inner {
	position: relative;
	width: calc(100% - 40px);
	max-width: 1160px;
	margin-left: auto;
	margin-right: auto;
}

.l-inner--md {
	max-width: 1360px;
}

.l-inner--lg {
	max-width: 1420px;
}

/* Module */

.noscript {
	font-size: 16px;
	line-height: 1.4;
	text-align: center;
	padding: 1em;
	border: 3px solid red;
}

.noscript span {
	color: red;
}

/*
#styleguide
heading-primary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-primary">見出し２です</p>
```
*/

.heading-primary {
	font-weight: 700;
	font-size: 4.4rem;
	letter-spacing: 0.1em;
	text-align: center;
}

.heading-primary--left {
	text-align: left;
}

/*
#styleguide
heading-secondary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-secondary">見出し２です</p>
```
*/

.heading-secondary {
	font-weight: 700;
	font-size: 3.2rem;
	letter-spacing: 0.1em;
}

/*
#styleguide
heading-tertiary

SP 20px / PC 26px
デフォルトは左寄せ
```
<p class="heading-tertiary">見出し２です</p>
```
*/

/*
#styleguide
text-base

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-base">ベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントですベースフォントです</p>
```
*/

.text-base {
	font-size: 1.8rem;
	letter-spacing: 0.1em;
}

.text-base p,
.text-base ol,
.text-base ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-lg

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-lg">大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです大きめの文字のテキストです</p>
```
*/

.text-lg {
	font-size: 2rem;
	line-height: 1.8;
}

.text-lg p,
.text-lg ol,
.text-lg ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-sm

SP 16px / PC 18px
デフォルトは左寄せ
```
<p class="text-sm">小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです小さめの文字のテキストです</p>
```
*/

.text-sm {
	font-size: 1.4rem;
	line-height: 1.8;
}

.text-sm p,
.text-sm ol,
.text-sm ul {
	margin-bottom: 1.8em;
}

/*
#styleguide
text-note

米印の下にテキストの回り込みが内容にします。
```
<p class="text-note">※テキストですテキストです。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。米印の下にテキストの回り込みが内容にします。</p>
```
*/

.text-note {
	padding-left: 1em;
	text-indent: -1em;
}

.buttons-wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 20px;
	margin-top: 30px;
}

/*
#styleguide
button-primary

SP 20px / PC 26px
デフォルトは左寄せ
```
<div class="buttons-wrap">
	<a href="#" class="button-primary">ボタン</a>
	<button type="button" class="button-primary">ボタン</button>
</div>
```
*/

.button-primary {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	background: #3B3838;
	width: 320px;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: #FFF;
	padding: 0.75em 1em;
	border-radius: 30px;
	text-decoration: none;
	border: none;
	outline: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.button-primary--colorless {
	background: transparent;
	border: 1px solid currentColor;
}

.button-primary:visited {
	color: #FFF;
}

/*
#styleguide
button-secondary

SP 20px / PC 26px
デフォルトは左寄せ
```
<div class="buttons-wrap">
	<a href="#" class="button-secondary">ボタン</a>
	<button type="button" class="button-secondary">ボタン</button>
</div>
```
*/

.bg-green {
	background: #008458;
}

.bg-ivory {
	background: #F8F5E3;
}

.bg-green-triangular {
	position: relative;
}

.bg-green-triangular::before {
	content: "";
	position: absolute;
	top: 0;
	left: 6.8%;
	-webkit-transform: translateY(calc(-100% + 3px));
	transform: translateY(calc(-100% + 3px));
	width: 9.375%;
	aspect-ratio: 1/1;
	min-width: 140px;
	background: url(../img/illust_01.svg) no-repeat center center/contain;
	z-index: 1;
}

.bg-green-triangular::after {
	content: "";
	position: absolute;
	top: 1px;
	left: 0;
	-webkit-transform: translateY(-100%);
	transform: translateY(-100%);
	width: 100%;
	height: 7.0833vw;
	background: #008458;
	clip-path: polygon(50% 0%, 100% 67%, 100% 100%, 0 100%, 0 67%);
}

.bg-green-jagged {
	position: relative;
}

.bg-green-jagged::before {
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	width: 100%;
	height: 6.25vw;
	background: url(../img/bg_jagged_01.svg) no-repeat bottom center/100% 100%;
	z-index: 1000;
}

.bg-white-jagged {
	position: relative;
}

.bg-white-jagged::before {
	content: "";
	position: absolute;
	top: 1px;
	left: 0;
	-webkit-transform: translateY(-100%);
	transform: translateY(-100%);
	width: 100%;
	height: 7.2917vw;
	background: url(../img/bg_jagged_02.svg) no-repeat bottom center/100% 100%;
	z-index: 1000;
}

.bg-noise {
	position: relative;
	background: url(../img/bg_noise.png) repeat center center/200px 200px;
}

.bg-noise::before {
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	width: 100%;
	height: 6.7708vw;
	background: url(../img/bg_jagged_03.svg) no-repeat bottom center/100% 100%;
	z-index: 1000;
}

.menu-btn {
	display: block;
	background: none;
	border: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	padding: 0;
	position: relative;
	z-index: 20000;
	overflow: hidden;
}

.menu-btn__icon {
	display: block;
	width: 40px;
	height: 26px;
	position: relative;
	margin: 0 auto;
}

.menu-btn__icon span {
	display: block;
	width: 100%;
	height: 4px;
	background: currentColor;
	position: absolute;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	-webkit-transition: 0.4s;
	transition: 0.4s;
}

.menu-btn__icon span:nth-child(1) {
	top: 0;
	-webkit-transform: translate(-50%, 0);
	transform: translate(-50%, 0);
}

.menu-btn__icon span:nth-child(2) {
	top: 50%;
}

.menu-btn__icon span:nth-child(3) {
	top: calc(100% - 2px);
}

.menu-btn.is-open .menu-btn__icon span {
	width: calc(100% + 8px);
}

.menu-btn.is-open .menu-btn__icon span:nth-child(1) {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(28deg);
	transform: translate(-50%, -50%) rotate(28deg);
}

.menu-btn.is-open .menu-btn__icon span:nth-child(2) {
	opacity: 0;
}

.menu-btn.is-open .menu-btn__icon span:nth-child(3) {
	top: 50%;
	-webkit-transform: translate(-50%, -50%) rotate(-28deg);
	transform: translate(-50%, -50%) rotate(-28deg);
}

.gnavi-wrap {
	background: #FFF;
	border-radius: 30px;
	padding: 20px 40px 40px;
}

.gnavi__item {
	position: relative;
}

.gnavi__item::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background-image: repeating-linear-gradient(90deg, #DFDFDF, #DFDFDF 10px, transparent 10px, transparent 18px);
}

.gnavi__item a {
	display: block;
	padding: 0.77em 0;
	font-weight: 700;
	font-size: 2.4rem;
	letter-spacing: 0.05em;
	color: #3B3838;
	text-decoration: none;
}

.gnavi__item a:visited {
	color: #3B3838;
}

.gnavi-sns {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 20px;
}

.gnavi-sns__item a {
	display: block;
	width: 30px;
	height: 30px;
}

.gnavi-sns__item img {
	display: block;
}

.gnavi-bottom {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.gnavi-bottom__logo {
	max-width: 150px;
}

.gnavi-bottom__logo img {
	display: block;
}

.footer {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: calc(60px + 6.25vw) 0 20px;
	color: #FFF;
	z-index: 1;
}

.footer__logo img {
	display: block;
}

.footer__heading {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	font-size: 2.6rem;
	letter-spacing: 0.1em;
}

.footer__heading::before {
	content: "";
	display: block;
	width: 50px;
	aspect-ratio: 1/1;
	background: url(../img/icon_contact.svg) no-repeat center center/contain;
}

.footer__info {
	letter-spacing: 0.1em;
	text-align: center;
}

.footer__info a {
  color: inherit;
}

.footer__info p:not(:first-child) {
	margin-top: 20px;
}

.footer__copyright {
	font-size: 1.4rem;
	letter-spacing: 0.1em;
}

.pagetop a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 10px;
	letter-spacing: 0.1em;
	color: #FFF;
}

.pagetop a:visited {
	color: currentColor;
}

.pagetop a::before {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	background: currentColor;
	clip-path: polygon(0 50%, 50% 0, 100% 50%, 65% 50%, 65% 100%, 35% 100%, 35% 50%);
}

.reservation-btn {
	position: fixed;
	bottom: 10px;
	right: 40px;
	z-index: 2500;
}

.reservation-btn a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 10px;
	width: 140px;
	aspect-ratio: 1/1;
	background: #C94328;
	border-radius: 50%;
	font-weight: 700;
	letter-spacing: 0.05em;
	color: #FFF;
	text-decoration: none;
}

.reservation-btn a::after {
	content: "";
	display: block;
	width: 50px;
	aspect-ratio: 1/1;
	-webkit-mask: url(../img/icon_reservation.svg) no-repeat center center/contain;
	mask: url(../img/icon_reservation.svg) no-repeat center center/contain;
	background: currentColor;
}

.mainvisual {
	position: relative;
	overflow: clip;
}

.mainvisual__logo {
	position: absolute;
	top: 6%;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 12.5521%;
}

.mainvisual__logo img {
	display: block;
}

.mainvisual__text {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, calc(-50% - 33px));
	transform: translate(-50%, calc(-50% - 33px));
	width: 9.375%;
	-webkit-filter: drop-shadow(0 0 10px #001900);
	filter: drop-shadow(0 0 10px #001900);
}

.mainvisual__text img {
	display: block;
}

.mainvisual__image img {
	display: block;
}

.news {
	padding: 20px 0 calc(80px + 7.0833vw);
}

.news__list {
	border-top: 1px solid #DFDFDF;
}

.news__item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	padding: 20px 10px;
	border-bottom: 1px solid #DFDFDF;
}

.news__item a {
	display: block;
}

.news__time {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 10em;
	margin-right: 20px;
	font-weight: 700;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	color: #3B3838;
}

.news__title {
	letter-spacing: 0.1em;
}

.news__buttons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.info {
	padding: 20px 0 80px;
	color: #FFF;
}

.info__list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	gap: 3.4483%;
}

.info__item {
	width: 22.4138%;
}

.info__item a {
	display: block;
	width: 100%;
	text-decoration: none;
}

.info__item a:visited {
	color: currentColor;
}

.info__icon {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	padding: clamp(3rem, 1.2222222222rem + 2.3148148148vw, 4rem) clamp(4rem, 2.2222222222rem + 2.3148148148vw, 5rem);
	background: #FFF;
	border-radius: 30px;
}

.info__text {
	display: block;
	margin-top: 10px;
	font-weight: 700;
	font-size: 2.2rem;
	letter-spacing: 0.1em;
	color: #FFF;
	text-align: center;
}

.about {
	position: relative;
	padding: calc(100px + 6.25vw) 0 calc(80px + 7.2917vw);
}

.about::after {
	content: "";
	position: absolute;
	top: 2.3%;
	right: 9.3%;
	width: 18.75%;
	min-width: 220px;
	aspect-ratio: 360/150;
	background: url(../img/illust_02.svg) no-repeat bottom center/100% 100%;
	z-index: 2000;
}

.about__2col {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
	gap: clamp(2rem, -7.4233128834rem + 12.2699386503vw, 10rem);
}

.about__2col__main {
	width: 35.9155%;
}

.about__2col__sub {
	width: 57.0423%;
	border-radius: 60px;
	overflow: hidden;
}

.about__2col__sub img {
	display: block;
}

.facility {
	padding: 20px 0 80px;
}

.facility-item {
	padding: clamp(5rem, 0.1020408163rem + 6.3775510204vw, 7.5rem) clamp(4rem, -3.8367346939rem + 10.2040816327vw, 8rem);
	background: #FFD900;
	border-radius: 60px;
}

.facility-item:not(:first-child) {
	margin-top: 60px;
}

.facility-item__heading {
	font-weight: 700;
	font-size: 4rem;
	letter-spacing: 0.05em;
}

.facility-item__content {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
	gap: 4%;
}

.facility-item__image-wrap {
	position: relative;
	width: 44%;
	padding: 0 40px 50px 0;
}

.facility-item__lg-image img {
	display: block;
	border-radius: 30px;
}

.facility-item__fig {
	position: absolute;
	bottom: 0;
	right: 0;
}

.facility-item__list {
	position: relative;
	width: 52%;
}

.facility-item__list::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background-image: repeating-linear-gradient(90deg, #FFF, #FFF 10px, transparent 10px, transparent 18px);
}

.facility-item__item {
	position: relative;
}

.facility-item__item::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
	background-image: repeating-linear-gradient(90deg, #FFF, #FFF 10px, transparent 10px, transparent 18px);
}

.facility-item__item a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	gap: 10px;
	padding: 10px;
	text-decoration: none;
}

.facility-item__item a:visited {
	color: currentColor;
}

.facility-item__text {
	display: block;
	font-weight: 700;
	font-size: 2.2rem;
	letter-spacing: 0.05em;
	color: #3B3838;
}

.facility-item__sm-image {
	-ms-flex-negative: 0;
	flex-shrink: 0;
	width: 150px;
	border-radius: 20px;
	overflow: hidden;
}

.facility-item__sm-image img {
	display: block;
}

.map {
	position: relative;
	padding: calc(80px + 6.7708vw) 0 calc(80px + 7.2917vw);
}

.map::after {
	content: "";
	position: absolute;
	top: 0;
	right: 15.6%;
	width: 16.1458%;
	min-width: 200px;
	aspect-ratio: 310/140;
	background: url(../img/illust_03.svg) no-repeat center center/contain;
	z-index: 2000;
}

.map__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.map__image {
	width: 77.5862%;
}

.map__image img {
	display: block;
}

.map__lead {
	font-weight: 700;
	font-size: 3.2rem;
	letter-spacing: 0.1em;
}

.access {
	padding: 60px 0 calc(80px + 7.0833vw);
}

.access__inner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
	gap: clamp(2rem, -7.4233128834rem + 12.2699386503vw, 10rem);
}

.access__main {
	width: 33.2355%;
}

.access__map {
	position: relative;
	width: 59.5588%;
	border-radius: 60px;
	overflow: hidden;
	aspect-ratio: 810/540;
}

.access__map iframe {
	position: absolute;
	top: -150px;
	left: 0;
	width: 100%;
	height: calc(100% + 300px);
}

.access__info {
	letter-spacing: 0.1em;
}

.access__info:not(:first-child) {
	margin-top: 5px;
}

.access__label {
	font-weight: 700;
}

.links {
	padding: 20px 0 80px;
}

.info-list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 60px;
}

.info-list__link {
	position: relative;
	display: block;
	padding: 40px clamp(15rem, 6.1111111111rem + 11.5740740741vw, 20rem) 40px clamp(3rem, -2.3333333333rem + 6.9444444444vw, 6rem);
	background: #FFD900;
	border-radius: 20px;
	font-weight: 700;
	font-size: 2.2rem;
	letter-spacing: 0.1em;
	color: #3B3838;
	text-decoration: none;
}

.info-list__link:visited {
	color: currentColor;
}

.info-list__link::after {
	content: "";
	position: absolute;
	bottom: 10px;
	right: 11%;
	width: 21.82%;
	min-width: 110px;
	aspect-ratio: 1/1;
}

.info-list__link--1::after {
	background: url(../img/illust_info_list_01.svg) no-repeat center center/contain;
}

.info-list__link--2::after {
	background: url(../img/illust_info_list_02.svg) no-repeat center center/contain;
}

.sns-list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
}

.sns-list__link {
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 6.8%;
	padding: 20px clamp(2rem, 0.2222222222rem + 2.3148148148vw, 3rem);
	background: #FFF;
	border-radius: 20px;
	font-weight: 700;
	font-size: 1.8rem;
	letter-spacing: 0.1em;
	color: #3B3838;
	text-decoration: none;
}

.sns-list__link:visited {
	color: currentColor;
}

.sns-list__link::before {
	content: "";
	display: block;
	width: 30px;
	height: 30px;
}

.sns-list__link--x::before {
	background: url(../img/icon_x.svg) no-repeat center center/contain;
}

.sns-list__link--instagram::before {
	background: url(../img/icon_instagram.png) no-repeat center center/contain;
}

.sns-list__link--facebook::before {
	background: url(../img/icon_facebook.svg) no-repeat center center/contain;
}

.scrollin {
	opacity: 0;
	-webkit-transform: translate(0, 70px);
	transform: translate(0, 70px);
}

.scrollin.is-visible {
	opacity: 1;
	-webkit-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
	transition: 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

@media screen and (min-width: 768px) {

.text-pc-left { /* pc */
	text-align: left;
}

.text-pc-center { /* pc */
	text-align: center;
}

.text-pc-right { /* pc */
	text-align: right;
}

}

@media screen and (max-width: 1000px) {

/* 1000px以下 */

.tab-grid-1col {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.tab-grid-2col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.tab-grid-3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.tab-grid-4col {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

.about__2col { /* 1000px以下 */
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: start;
}

.about__2col__main { /* 1000px以下 */
	width: 60%;
}

.about__2col__sub { /* 1000px以下 */
	width: 40%;
	border-radius: 40px;
}

.access__inner { /* 1000px以下 */
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: start;
}

.access__main { /* 1000px以下 */
	width: 50%;
}

.access__map { /* 1000px以下 */
	width: 50%;
	border-radius: 40px;
}

}

@media screen and (max-width: 767px) {

.text-sp-left { /* sp */
	text-align: left;
}

.text-sp-center { /* sp */
	text-align: center;
}

.text-sp-right { /* sp */
	text-align: right;
}

.sp-only { /* sp */
	display: block !important;
}

.sp-only-2 { /* sp */
	display: inline-block !important;
}

.pc-only { /* sp */
	display: none !important;
}

.pc-only-2 { /* sp */
	display: none !important;
}

/* sp */

.sp-grid-1col {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
}

.sp-grid-2col {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
}

.sp-grid-3col {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.sp-grid-4col {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}

.--sp-grid-2col { /* sp */
	grid-template-columns: repeat(2, 1fr);
}

.--sp-grid-1col { /* sp */
	grid-template-columns: repeat(1, 1fr);
}

.l-wrapper { /* sp */
	font-size: 1.6rem;
}

.l-header { /* sp */
	padding: 15px;
}

.l-navi { /* sp */
	max-height: inherit;
	font-size: 1.6rem;
}

.l-navi__inner { /* sp */
	padding: 6rem 30px 4rem;
}

.heading-primary { /* sp */
	font-size: 3rem;
}

.heading-secondary { /* sp */
	font-size: 2.2rem;
}

.text-base { /* sp */
	font-size: 1.6rem;
}

.bg-green-triangular::before { /* sp */
	left: 2%;
	-webkit-transform: translateY(calc(-100% + 15px));
	transform: translateY(calc(-100% + 15px));
	width: 100px;
	height: 100px;
}

.gnavi-wrap { /* sp */
	padding: 20px;
	border-radius: 20px;
}

.gnavi__item a { /* sp */
	font-size: 2rem;
	padding: 0.8em 0;
}

.footer__heading { /* sp */
	font-size: 2rem;
}

.footer__copyright { /* sp */
	font-size: 1.2rem;
}

.pagetop a::before { /* sp */
	width: 15px;
	height: 15px;
}

.reservation-btn { /* sp */
	right: 10px;
}

.reservation-btn a { /* sp */
	gap: 5px;
	font-size: 1.4rem;
	width: 85px;
}

.reservation-btn a::after { /* sp */
	width: 30px;
}

.mainvisual__logo { /* sp */
	top: 3.5%;
	width: 16%;
	min-width: 110px;
}

.mainvisual__text { /* sp */
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	top: 48%;
	width: 12%;
	min-width: 85px;
}

.mainvisual__image { /* sp */
	position: relative;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	min-width: 700px;
	z-index: -1;
}

.news__item { /* sp */
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	padding: 15px 0;
}

.news__time { /* sp */
	margin-right: 0;
	font-size: 1.4rem;
}

.news__title { /* sp */
	margin-top: 0.2em;
}

.info__list { /* sp */
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	gap: 30px 20px;
}

.info__item { /* sp */
	width: calc(50% - 10px);
}

.info__icon { /* sp */
	padding: 20px 30px;
}

.info__text { /* sp */
	font-size: 1.8rem;
}

.about::after { /* sp */
	top: 0;
	right: 2%;
}

.about__2col { /* sp */
	-webkit-box-orient: vertical;
	-webkit-box-direction: reverse;
	-ms-flex-direction: column-reverse;
	flex-direction: column-reverse;
	gap: 30px;
}

.about__2col__main { /* sp */
	width: 100%;
}

.about__2col__sub { /* sp */
	width: 100%;
	border-radius: 30px;
}

.facility-item { /* sp */
	padding: clamp(3rem, 1.0867346939rem + 5.1020408163vw, 5rem) clamp(2rem, -0.8698979592rem + 7.6530612245vw, 5rem);
	border-radius: 40px;
}

.facility-item:not(:first-child) { /* sp */
	margin-top: 30px;
}

.facility-item__heading { /* sp */
	font-size: 2.8rem;
}

.facility-item__content { /* sp */
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	gap: 40px;
}

.facility-item__image-wrap { /* sp */
	padding: 0 0 40px 0;
	width: 100%;
}

.facility-item__list { /* sp */
	width: 100%;
}

.facility-item__item a { /* sp */
	padding: 10px 0;
}

.facility-item__text { /* sp */
	font-size: 1.8rem;
}

.facility-item__sm-image { /* sp */
	width: 40%;
}

.map::after { /* sp */
	right: 5%;
}

.map__image { /* sp */
	width: 100%;
}

.map__lead { /* sp */
	font-size: 2.8rem;
}

.access__inner { /* sp */
	gap: 30px;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.access__main { /* sp */
	width: 100%;
}

.access__map { /* sp */
	width: 100%;
	border-radius: 30px;
}

.links { /* sp */
	padding: 60px 0 80px;
}

.info-list { /* sp */
	grid-template-columns: 1fr;
	gap: 20px;
}

.info-list__link { /* sp */
	padding: 20px clamp(12rem, 9.1374045802rem + 7.6335877863vw, 15rem) 20px 30px;
	font-size: 1.8rem;
}

.info-list__link::after { /* sp */
	right: 8%;
	width: 80px;
	min-width: auto;
}

.sns-list { /* sp */
	grid-template-columns: 1fr;
	gap: 20px;
}

.sns-list__link { /* sp */
	gap: 20px;
	padding: 20px 30px;
	font-size: 1.6rem;
}

}

