*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
	border: 0;
	font: inherit;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

html {
	line-height: 1;
}

ol,
ul {
	list-style: none;
}

li,
dd {
	list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
	display: block;
}

img {
	border: none;
	vertical-align: bottom;
}

a {
	cursor: pointer;
	text-decoration: none;
}

address {
	font-style: normal;
}

@font-face {
	font-family: "A1 Mincho";
	font-style: normal;
	font-weight: 400;
	src: url("/assets/fonts/SatsukiGendaiMincho-M.ttf") format("opentype");
}

body {
	background: #fff;
	color: #141414;
	font-family: "A1 Mincho", serif;
	line-height: 1.5;
}

img {
	height: auto;
	max-width: 100%;
}

a {
	color: inherit;
}

.l-inner {
	padding-left: 20px;
	padding-right: 20px;
	width: 100%;
}

.u-separate {
	margin-bottom: 24px;
	margin-top: 24px;
}

.header {
	position: relative;
}

.header__inner {
	display: flex;
	justify-content: space-between;
	padding: 20px;
	position: absolute;
	width: 100%;
	z-index: 100;
}

.header__logo {
	height: 55px;
	width: 91px;
}

.header__logo img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.header__nav {
	display: none;
}

.header__link {
	color: #fff;
	font-size: 18px;
}

.header__open {
	align-items: flex-start;
	background: transparent;
	cursor: pointer;
	display: flex;
	flex-direction: column;
	height: 50px;
	justify-content: space-between;
	transition: 0.3s;
	width: 50px;
}

.header__open-bar {
	background: #fff;
	height: 2px;
	transform-origin: right center;
	transition: 0.3s;
	width: 50px;
}

.header__open-bar:nth-child(2) {
	width: 25px;
}

.header__open-bar:nth-child(3) {
	opacity: 0;
}

/* クリック後（バツ状態） */

.header__open.active .header__open-bar {
	background: #141414;
}

.header__open.active .header__open-bar:nth-child(1) {
	transform: rotate(-45deg) translate(8px, 8px);
	width: 35px;
}

.header__open.active .header__open-bar:nth-child(2) {
	transform: rotate(45deg) translate(8px, -8px);
	width: 35px;
}

.header__open.active .header__open-bar:nth-child(3) {
	opacity: 0;
}

.drawer {
	background: #fff; /* 背景色 */
	height: 100%;
	left: 0;
	overflow-y: auto;
	padding-top: 150px;
	position: fixed;
	top: -100%;
	transition: top 0.4s ease; /* スライドのアニメーション */
	width: 100%;
	z-index: 99;
}

/* 表示状態 */

.drawer.is-open {
	top: 0;
}

.drawer-top-nav {
	align-items: start;
	display: flex;
	flex-direction: column;
	margin-left: auto;
	margin-right: auto;
	max-width: 250px;
	padding-left: 20px;
	padding-right: 20px;
}

.drawer__link {
	border-bottom: 1px solid #333;
	font-size: 20px;
	margin-top: 10px;
	padding-bottom: 10px;
	width: 100%;
}

.drawer__btm {
	bottom: 100px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

.address__flex {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.d-mail {
	margin-top: 20px;
}

.fix-btn-pc {
	display: none;
}

.fix-btn-sp {
	align-items: center;
	background: #111;
	bottom: 0;
	color: #fff;
	display: block;
	display: flex;
	font-size: 20px;
	font-weight: 400;
	height: 65px;
	justify-content: center;
	position: fixed;
	width: 100%;
	z-index: 101;
	padding-left: 30px;
}

.fix-btn-sp::after {
	background: url(../img/2x/btn-top@2x.webp) no-repeat center center/cover;
	content: "";
	height: 20px;
	left: 16%;
	position: absolute;
	top: 53%;
	transform: translateY(-50%);
	width: 20px;
}

.top__bg {
	position: relative;
	width: 100%;
}

.top__bg img {
	width: 100%;
}

.top__main-sp {
	color: #fff;
	font-size: 31px;
	font-weight: 400;
	left: 50%;
	position: absolute;
	text-orientation: upright; /* 文字を縦向きに整える */
	top: 10%;
	transform: translateX(-50%);
	writing-mode: vertical-rl; /* 縦書き（右から左へ流れる） */
	z-index: 2;
}

.top__main {
	display: none;
}

.top__sub {
	display: none;
}

.section {
	margin-top: 100px;
}

.head__main {
	color: #e9a037;
	font-size: 40px;
	font-weight: 400;
	line-height: 1.4;
	text-align: center;
}

.head__sub {
	font-family: "Noto Serif JP", serif;
	font-size: 17px;
	line-height: 1.7;
	margin-top: 50px;
	text-align: center;
}

.sce {
	overflow: hidden;
}

.sce__head {
	align-items: center;
	display: flex;
	font-size: 25px;
	gap: 15px;
	justify-content: center;
}

.sce__head::before {
	background: url(../img/2x/sce-ar@2x.webp) no-repeat center center/cover;
	content: "";
	display: block;
	height: 20px;
	width: 20px;
}

.sce__head::after {
	background: url(../img/2x/sce-ar@2x.webp) no-repeat center center/cover;
	content: "";
	display: block;
	height: 20px;
	width: 20px;
}

.sce__p {
	font-size: 15px;
	margin-top: 15px;
	text-align: center;
}

.sce__crender {
	align-items: center;
	background: #ccc;
	display: flex;
	height: 414px;
	justify-content: center;
	margin-top: 50px;
	width: 100%;
}

.mv__item {
	margin-top: 100px;
	position: relative;
	overflow: hidden;
}

.mv__item.rrr .mv-item__bg {
	left: -20px;
}

.mv__item.rrr .mv-item__bg img {
	-o-object-fit: cover;
	-o-object-position: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 100%;
	width: 100%;
}

.mv__item.rrr .mv-item__head {
	margin-left: auto;
	margin-right: 20px;
}

.mv__item.rrr .mv-item__main {
	margin-left: auto;
	margin-right: 30px;
}

.mv__item:nth-child(2) .mv-item__bg {
	top: 80px;
}

.mv__item:nth-child(3) .mv-item__bg {
	top: 100px;
}

.mv-item__bg {
	height: 210px;
	position: absolute;
	right: -20px;
	top: 60px;
	width: 74%;
	z-index: -1;
}

.mv-item__bg img {
	-o-object-fit: cover;
	-o-object-position: 0;
	height: 100%;
	object-fit: cover;
	object-position: 0;
	width: 100%;
}

.mv-item__head {
	font-family: "Noto Serif JP", serif;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.7;
	margin-left: 20px;
	text-align: center;
	text-orientation: upright; /* 文字を縦向きに整える */
	writing-mode: vertical-rl; /* 縦書き（右から左へ流れる） */
}

.mv-item__main {
	color: #e9a037;
	font-family: "Noto Serif JP", serif;
	font-size: 74px;
	font-weight: bold;
	margin-left: 50px;
	margin-top: 20px;
	width: -moz-fit-content;
	width: fit-content;
}

.mv-item__body {
	display: flex;
	flex-direction: column;
	font-size: 15px;
	line-height: 1.7;
	margin-left: 20px;
	margin-top: 30px;
}

.content {
	background: url(../img/2x/bg@2x.webp) no-repeat center center/cover;
	margin-top: 200px;
	padding-bottom: 100px;
	padding-top: 100px;
}

.content__body {
	background: rgba(255, 255, 255, 0.8);
	border-radius: 15px;
	padding: 50px 20px;
	position: relative;
}

.content__body::before {
	background: url(../img/2x/EKyiaz@2x.webp) no-repeat center center/cover;
	content: "";
	height: 140px;
	left: 50%;
	position: absolute;
	top: -120px;
	transform: translateX(-50%);
	width: 60px;
	z-index: 2;
}

.content__head {
	color: #e9a037;
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
	white-space: nowrap;
}

.content__p {
	font-size: 15px;
	line-height: 1.7;
	margin-top: 50px;
	text-align: center;
}

.content__flex {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 50px;
}

.content__flex-top {
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	text-align: center;
}

.content__flex-text {
	font-size: 15px;
	line-height: 1.7;
	margin-top: 30px;
}

.content__flex-img {
	margin-left: auto;
	margin-right: auto;
	width: 70%;
}

.content__flex-img img {
	width: 100%;
}

.content__flex-sub {
	font-size: 14px;
	margin-top: 10px;
	text-align: center;
}

.content__flex-name {
	font-size: 20px;
	margin-top: 15px;
	text-align: center;
}

.hotel-item {
	border: 1px solid #111;
	border-radius: 15px;
	display: flex;
	flex-direction: column;
	gap: 30px;
	margin-top: 50px;
	padding: 20px 25px;
}

.hotel-item__head {
	align-items: center;
	display: flex;
	flex-direction: column;
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	gap: 5px;
	text-align: center;
}

.hotel-item__head span {
	font-size: 15px;
}

.hotel-item__body {
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.hotel-item__body-top {
	font-size: 15px;
}

.top-sub {
	font-size: 15px;
}

.hotel-item__body-body {
	display: flex;
	flex-direction: column;
	font-size: 20px;
	gap: 10px;
}

.price {
	font-size: 27px;
}

.map__text {
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
	padding-left: 20px;
	padding-right: 20px;
	width: -moz-fit-content;
	width: fit-content;
}

.sns {
	margin-bottom: 200px;
}

.sns__inner {
	border: 1px solid #111;
	border-radius: 15px;
	padding: 30px;
}

.sns__head {
	font-family: "Noto Serif JP", serif;
	font-size: 24px;
	line-height: 1.4;
	text-align: center;
}

.sns__tel {
	align-items: center;
	background: #3e3a39;
	border-radius: 5px;
	color: #fff;
	display: flex;
	height: 40px;
	justify-content: center;
	margin-top: 20px;
	width: 100%;
}

.sns__tel-pc {
	display: block;
	font-family: "Noto Serif JP", serif;
	font-size: 36px;
	margin-top: 20px;
	text-align: center;
}

.sns__insta {
	align-items: center;
	background: #da0d92;
	border-radius: 5px;
	color: #fff;
	color: #fff;
	display: flex;
	height: 35px;
	justify-content: center;
	margin-top: 20px;
	width: 100%;
}

.sns__line {
	align-items: center;
	background: #23b94f;
	border-radius: 5px;
	color: #fff;
	color: #fff;
	display: flex;
	height: 35px;
	justify-content: center;
	margin-top: 20px;
	width: 100%;
}

.sns-pc {
	display: none;
}

.sns__imgs {
	display: flex;
	gap: 30px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 30px;
	width: 60%;
}

.footer {
	background: url(../img/2x/btm-bg@2x.webp) no-repeat center center/cover;
	padding-bottom: 120px;
	padding-top: 100px;
	width: 100%;
}

.footer__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 10px;
	text-align: center;
}

.footer__icon {
	width: 140px;
}

.footer__tel {
	color: #fff;
	font-size: 24px;
	margin-top: 50px;
}

.footer__address {
	color: #fff;
}

.footer__email {
	color: #fff;
}

.insta-a {
	height: 100px;
	position: absolute;
	right: 15px;
	top: 300px;
}

.insta-a img {
	height: 100%;
}

a:hover {
	opacity: 0.7;
}

main {
	overflow: hidden;
	position: relative;
}

.wabe {
	animation: waveMove 10s linear infinite;
	bottom: -2px;
	position: absolute;
	width: 200%;
}

.wabe img {
	width: 200%;
}

.head {
	margin-top: 50px;
}

.header__logo img {
	transition: filter 0.3s ease; /* なめらかに色を変える */
}

/* スクロール後に黒にしたい場合 */

.header__logo.scroll img {
	filter: brightness(0); /* 黒に変える */
}

/* スクロール後 */

.header__open.scroll .header__open-bar {
	background-color: black; /* 黒に変える */
}

.container_05 {
	left: 7%;
	position: absolute;
	top: 85%;
	z-index: 1;
}

.scrollbar-text_05 {
	bottom: 0;
	color: #fff;
	display: inline-block;
	font-family: serif;
	font-size: 14px;
	left: 50%;
	letter-spacing: 0.2em;
	line-height: 1;
	padding: 10px 10px 160px;
	position: absolute;
	text-transform: uppercase;
	transform: translateX(-50%);
	writing-mode: vertical-lr;
}

.scrollbar_05 {
	bottom: 1px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

.scrollbar_05::after {
	animation: liner 2.5s cubic-bezier(1, 0, 0, 1) infinite;
	background: #fff;
	bottom: 0;
	content: "";
	height: 150px;
	left: 0;
	position: absolute;
	width: 1px;
}

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

.l-inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 800px;
}

.hidden-pc {
	display: none;
}

.header__inner {
	padding: 30px;
	position: absolute;
}

.header__logo {
	height: 97px;
	width: 160px;
}

.header__nav {
	display: flex;
	gap: 20px;
}

.header__open {
	display: none;
}

.fix-btn-pc {
	background: #111; /* 背景色 */
	color: #fff;
	display: inline-block;
	font-size: 20px;
	font-weight: 400;
	padding: 50px 20px 30px 20px;
	position: fixed;
	right: 0;
	text-align: center;
	text-decoration: none;
	text-orientation: upright; /* 文字を縦向きに整える */
	top: 100px;
	writing-mode: vertical-rl; /* 縦書き（右から左へ流れる） */
	z-index: 101;
}

.fix-btn-pc::after {
	background: url(../img/2x/btn-top@2x.webp) no-repeat center center/cover;
	content: "";
	height: 20px;
	left: 50%;
	position: absolute;
	top: 20px;
	transform: translateX(-50%);
	width: 20px;
}

.fix-btn-sp {
	display: none;
}

.top__main-sp {
	display: none;
}

.top__main {
	color: #fff;
	display: block;
	font-size: 63px;
	font-weight: 400;
	left: 50%;
	position: absolute;
	top: 200px;
	transform: translateX(-50%);
	white-space: nowrap;
}

.top__sub {
	color: #fff;
	display: block;
	font-family: "A1 Mincho", serif;
	font-size: 21px;
	font-weight: 400;
	left: 50%;
	line-height: 1.4;
	position: absolute;
	text-align: center;
	top: 300px;
	transform: translateX(-50%);
	white-space: nowrap;
}

.head__main {
	font-size: 52px;
}

.head__sub {
	font-size: 21px;
}

.sce__head::before {
	height: 25px;
	width: 25px;
}

.sce__head::after {
	height: 25px;
	width: 25px;
}

.sce__head::after {
	height: 25px;
	width: 25px;
}

.sce__head {
	font-size: 35px;
}

.sce__crender {
	height: 502px;
}

.mv__item {
	margin-top: 200px;
}

.mv__item.rrr .mv-item__bg {
	width: 70%;
}

.mv__item.rrr .mv-item__head {
	margin-right: 220px;
}

.mv__item.rrr .mv-item__main {
	margin-right: 100px;
}

.mv__item:nth-child(2) .mv-item__bg {
	top: -100px;
}

.mv__item:nth-child(2) .mv-item__body {
	margin-left: 150px;
}

.mv__item:nth-child(3) .mv-item__bg {
	top: -60px;
}

.mv__item:nth-child(3) .mv-item__main {
	margin-left: 220px;
	margin-top: 0;
}

.mv-item__bg {
	height: 420px;
	top: -80px;
	width: 70%;
}

.mv-item__head {
	font-size: 23px;
	margin-left: 220px;
}

.mv-item__main {
	font-size: 155px;
	margin-left: 100px;
}

.mv-item__body {
	flex-direction: row;
	font-size: 16px;
	gap: 30px;
	margin-left: 430px;
}

.content {
	padding-bottom: 200px;
}

.content__body {
	padding: 50px 30px;
}

.content__body::before {
	height: 335px;
	left: 0px;
	top: 200px;
	width: 160px;
}

.content__head {
	font-size: 32px;
}

.content__p {
	font-size: 16px;
}

.content__flex {
	align-items: end;
	flex-direction: row;
	gap: 5px;
}

.content__flex-top {
	font-size: 27px;
	text-align: left;
}

.content__flex-text {
	font-size: 16px;
}

.content__flex-right {
	flex-shrink: 0;
	width: 200px;
}

.content__flex-img {
	width: 100%;
}

.hotel-item {
	flex-direction: row;
	padding: 50px;
}

.hotel-item__head {
	flex-shrink: 0;
	font-size: 30px;
	width: 80px;
}

.hotel-item__body-top {
	font-size: 17px;
}

.top-sub {
	font-size: 17px;
}

.hotel-item__body-body {
	flex-direction: row;
	font-size: 24px;
	gap: 30px;
	justify-content: space-between;
}

.price {
	font-size: 30px;
}

.sns__inner {
	padding: 50px;
}

.sns-sp {
	display: none;
}

.sns-pc {
	display: block;
}

.footer {
	padding-bottom: 100px;
	padding-top: 80px;
}

.footer__icon {
	width: 160px;
}

.footer__tel {
	font-size: 28px;
}

.insta-a {
	top: 380px;
}

.container_05 {
	left: 3%;
}

}

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

.top__main-sp {
	font-size: 28px;
}

}

@keyframes waveMove {

0% {
	transform: translateX(0);
}

100% {
	transform: translateX(-50%);
}

/* 画像の半分ずらしてループ */

}

@keyframes liner {

0% {
	transform: scale(1, 0);
	transform-origin: 0 0;
}

30% {
	transform: scale(1, 1);
	transform-origin: 0 0;
}

70% {
	transform: scale(1, 1);
	transform-origin: 0 100%;
}

100% {
	transform: scale(1, 0);
	transform-origin: 0 100%;
}

}
.hotel-item__body-body__flex {
  white-space: nowrap;
}

/* ============================
   TOPスライダー（最終版）
   ============================ */

/* ヒーロー全体 */
.top {
  position: relative;
  background: none !important;  /* もとの背景は使わない */
}

/* もとの1枚画像 <img> や <picture> を完全に非表示 */
.top__bg > img,
.top__bg > picture {
  display: none !important;
}

/* スライダー領域 */
.top__bg {
  position: relative;
  width: 100%;
  height: 75vh;        /* 画面の 75% の高さ */
  min-height: 480px;   /* 小さい画面でもつぶれないように最低高さ */
  overflow: hidden;
}

/* スライダー本体を全面に広げる */
.top__slider {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

/* 各スライド */
.top__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
}

/* JS が動かなくても1枚目だけは表示 */
.top__slide:first-child {
  opacity: 1;
}

/* スライド画像 */
.top__slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 表示中のスライド */
.top__slide.is-active {
  opacity: 1;
  z-index: 1;
}

/* 表示中の画像だけ、ゆっくり右→左に5%動かす */
.top__slide.is-active img {
  animation: slidePan 5s linear forwards;
}

@keyframes slidePan {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-5%); }
}

/* キャッチコピーを最前面に固定 */
.top__head {
  position: absolute;
  inset: 0;
  width: 100%;
  z-index: 10;
  pointer-events: none;   /* クリックは下の要素へ通す */
}

/* テキストだけは選択などできるようにする場合 */
.top__head h1,
.top__head p {
  pointer-events: auto;
}
/* ============================
   TOPスライダー 完全上書き
   ============================ */

.top {
  position: relative;
}

/* ヒーローエリア全体の箱 */
.top__bg {
  position: relative;
  width: 100%;
  height: 75vh;        /* ヒーローの高さ */
  min-height: 480px;
  overflow: hidden;
  background: none !important;
}

/* ▼ もともとの1枚画像（top-pc@2x.webp / top@2x.webp）を強制的に消す */
/* 直下の img / picture を全部非表示 */
.top__bg > img,
.top__bg > picture {
  display: none !important;
}

/* ファイル名でピンポイントに殺す保険（どこにあっても消える） */
.top img[src*="top-pc"],
.top img[src*="top@2x"] {
  display: none !important;
}

/* ▼ スライダー本体を .top__bg 全面に広げる */
.top__slider {
  position: absolute;
  inset: 0;
  width: 110%;
  height: 110%;
  z-index: 1;
}

/* 各スライドの基本 */
.top__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
}

/* 念のため：1枚目は必ず表示 */
.top__slide:first-child {
  opacity: 1;
}

/* スライド画像は少し大きくしておく（はみ出させる） */
.top__slide img {
  width: 105%;
  height: 105%;
  object-fit: cover;
}

/* 表示中のスライドだけ、右→左へゆっくり動かす */
.top__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.top__slide.is-active img {
  animation: slidePan 10s linear forwards;
}

/* 内側で 5% だけパンさせる（外側は常に隠れている） */
@keyframes slidePan {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-5%);
  }
}

/* ▼ キャッチコピーを常に最前面に固定 */
.top__head {
  position: absolute;
  inset: 0;
  width: 100%;
  z-index: 20;
  pointer-events: none; /* クリックは下に通す */
}

/* もともとの .top__main / .top__sub の absolute 指定はそのままでOK */
