/* ----------- header ----------- */

.header {
	left: 0;
	position: fixed;
	top: 0;
	transition: 0.5s;
	width: 100%;
	z-index: 99;
}

.header.--bk {
	-webkit-backdrop-filter: blur(2px);
	backdrop-filter: blur(2px);
	background-color: rgba(242, 240, 237, 0.4666666667);
}

.header.--bk .header__logo {
	opacity: 1;
	pointer-events: all;
}

.header.--bk span {
	background-color: #000;
}

.header__wrap {
	margin: 0 auto;
	padding-inline: 35px;
}

.header__inner {
	align-items: center;
	display: flex;
	justify-content: space-between;
	padding-block: 16px;
	transition: 0.5s;
	width: 100%;
}

.header__logo {
	aspect-ratio: 136/58;
	display: block;
	opacity: 0;
	pointer-events: none;
	position: relative;
	transition: 0.3s;
	width: 73px;
	z-index: 0;
}

.header__logo:hover {
	opacity: 0.7;
}

.header__logo img {
	transition: 0.5s;
}

.header__drawer-icon {
	cursor: pointer;
	display: flex;
	flex-direction: column;
	height: 20px;
	justify-content: space-between;
	margin-left: auto;
	position: relative;
	transition: 0.3s;
	width: 29px;
	z-index: 101;
}

.header__drawer-icon:hover {
	opacity: 0.7;
}

.header__drawer-icon span {
	background-color: #fff;
	border-radius: 1px;
	display: block;
	height: 2px;
	transform-origin: center;
	transition: background-color 0.5s, transform 0.3s;
	width: 100%;
}

.header__drawer-icon.--open span {
	background: #000;
}

.header__drawer-icon.--open span:nth-child(1) {
	transform: translateY(9px) rotate(45deg);
}

.header__drawer-icon.--open span:nth-child(2) {
	opacity: 0;
}

.header__drawer-icon.--open span:nth-child(3) {
	transform: translateY(-9px) rotate(-45deg);
}

.g-nav {
	background: #f2f0ed;
	height: 100dvh;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	right: 0;
	top: 0;
	transition: 0.7s;
	width: 100%;
	z-index: 100;
}

.g-nav.--open {
	opacity: 1;
	pointer-events: auto;
}

.g-nav__inner {
	align-items: end;
	display: flex;
	flex-direction: column;
	padding-inline: 35px;
	padding-top: 103px;
}

.g-nav__lists {
	display: flex;
	flex-direction: column;
	gap: 24px;
	max-width: 400px;
	width: 100%;
}

.g-nav__link {
	font-size: 20px;
	letter-spacing: 7px;
	line-height: 17px;
	transition: 0.4s;
}

.g-nav__link:hover {
	opacity: 0.6;
	padding-left: 10px;
}

.g-nav__bg {
	background: #353535;
	height: 100dvh;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	right: 0;
	top: 0;
	transition: 0.7s;
	width: 100%;
}

.g-nav__bg.--open {
	opacity: 0.3;
	pointer-events: all;
}

/* ----------- TOP ----------- */

.index .hero {
	animation: bg-zoom 1.2s ease-out forwards;
	opacity: 0;
	position: relative;
	transform: scale(1.01);
	transition: opacity 2s ease-out;
	width: 100%;
	z-index: 0;
}

.index .hero__content {
	height: 100vh;
	left: 50%;
	max-width: 1200px;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	z-index: 3;
}

.index .hero__title {
	color: #fff;
	font-size: 16px;
	left: 50%;
	letter-spacing: 3px;
	opacity: 0;
	position: absolute;
	text-align: center;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.3137254902);
	top: 46%;
	transform: translate(-50%, -50%);
	white-space: nowrap;
	z-index: 2;
}

.index .hero__logo {
	opacity: 0;
	position: absolute;
	right: 20px;
	top: 48%;
	transform: translateY(-50%);
	width: 92px;
	z-index: 2;
}

.index .hero__img {
	height: 100vh;
	width: 100vw;
}

.index .hero__img img {
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center;
	object-position: center;
}

.index .sec01__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 38px;
	padding-block: 38px;
}

.index .sec01__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2em;
	width: 100%;
}

.index .sec01__text {
	font-size: 15px;
	letter-spacing: 5.25px;
	line-height: 28px;
}

.index .sec01__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 20px;
	width: 100%;
}

.index .sec02 {
	padding-top: 16px;
}

.index .sec02__items {
	display: flex;
	flex-direction: column;
	gap: 52px;
}

.index .sec02__item {
	color: #fff;
	display: block;
	position: relative;
	width: 100%;
}

.index .sec02__item:hover .sec02__arrow {
	transform: translateX(0);
}

.index .sec02__content {
	display: flex;
	flex-direction: row-reverse;
	position: absolute;
	right: 29px;
	top: 16px;
	z-index: 1;
}

.index .sec02__title {
	font-size: 35px;
	letter-spacing: 1px;
	text-shadow: 0px 0px 5px #353535;
	writing-mode: vertical-rl;
}

.index .sec02__text {
	font-size: 15px;
	letter-spacing: 0.5px;
	line-height: 30px;
	padding-top: 7px;
	text-shadow: 0px 0px 10px #353535, 0px 0px 10px #353535;
	writing-mode: vertical-rl;
}

.index .sec02__block {
	bottom: 17px;
	left: 0px;
	margin-inline: 46px 50px;
	overflow: hidden;
	position: absolute;
	z-index: 1;
}

.index .sec02__label {
	font-size: 19px;
	font-weight: 400;
	letter-spacing: 6.65px;
	line-height: 24px;
	padding-left: 5px;
	text-shadow: 0px 0px 10px #353535, 0px 0px 10px #353535;
}

.index .sec02__arrow {
	transform: translateX(-70.27%);
	transition: 0.7s;
	width: 100%;
}

.index .sec02__bg {
	overflow: hidden;
}

.index .sec03 {
	margin-top: 80px;
}

.index .sec04 {
	padding-block: 60px;
}

.index .sec04__heading {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.index .sec04__title {
	font-size: 28px;
	letter-spacing: 9.8px;
	line-height: 28px;
}

.index .sec04__line {
	background: #353535;
	display: block;
	height: 41px;
	width: 1px;
}

.index .sec04__items {
	display: flex;
	flex-direction: column;
	gap: 21px;
	margin-top: 21px;
}

.index .sec04__item {
	border-bottom: 1px solid #7b725a;
	padding-bottom: 16px;
}

.index .sec04__item:hover .sec04__item-content {
	opacity: 0.7;
	transform: translateX(3%);
}

.index .sec04__item-content {
	display: flex;
	flex-direction: column;
	gap: 10px;
	transition: 0.3s;
}

.index .sec04__item-meta {
	font-size: 12px;
}

.index .sec04__item-title {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	color: #353535;
	font-size: 15px;
	letter-spacing: 5.25px;
	line-height: 28px;
	overflow: hidden;
	text-overflow: ellipsis;
}

.index .sec04__link {
	align-items: center;
	display: flex;
	gap: 5px;
	margin-left: auto;
	margin-top: 28px;
	overflow: hidden;
	padding-right: 20px;
	transition: 0.3s;
	width: -moz-fit-content;
	width: fit-content;
}

.index .sec04__link:hover {
	opacity: 0.7;
}

.index .sec04__link:hover .--arrow {
	transform: translateX(10px);
}

.index .sec04__link-text {
	color: #7b725a;
	font-size: 20px;
	letter-spacing: 3.5px;
	line-height: normal;
	transition: 0.3s;
}

.index .sec04__link-text.--arrow {
	font-size: 20px;
	line-height: 1;
	padding-top: 6px;
}

/* p-shop */

.p-shop {
	background: #d9ceaf;
	padding-block: 60px;
}

.p-shop__heading {
	align-items: center;
	color: #000;
	display: flex;
	flex-direction: column;
	gap: 28px;
}

.p-shop__title {
	font-size: 20px;
	letter-spacing: 7px;
	line-height: 28px;
	text-align: center;
}

.p-shop__desc {
	font-size: 14px;
	letter-spacing: 4.9px;
	line-height: 28px;
	width: -moz-fit-content;
	width: fit-content;
}

.p-shop__swiper {
	margin-top: 50px;
}

.p-shop .swiper-slide {
	width: auto;
}

.p-shop__card:hover .p-shop__img img {
	scale: 1.1;
}

.p-shop__img {
	overflow: hidden;
	width: 160px;
}

.p-shop__item-container {
	margin-inline: auto;
	margin-top: 44px;
	max-width: 600px;
	width: 100%;
}

.p-shop__item {
	position: relative;
}

.p-shop__item.--fir {
	margin-inline: auto 21px;
	width: 200px;
	z-index: 1;
}

.p-shop__item.--sec {
	margin-top: -50px;
	width: 300px;
	z-index: 3;
}

.p-shop__item.--sar {
	margin-left: auto;
	margin-top: -50px;
	width: 300px;
	z-index: 2;
}

.p-shop__button {
	margin: 50px auto 0;
}

/* ----------- about ----------- */

.about { /* sec01 */
}

.about .c-fv {
	background: url(../img/hero-img1.webp) no-repeat center center/cover;
}

.about .sec01 {
	padding-block: 38px 100px;
}

.about .sec01__container {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.about .sec01__content {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.about .sec01__content.--table {
	gap: 5px;
}

.about .sec01__text {
	font-size: 15px;
	letter-spacing: 5.25px;
	line-height: 31px;
}

.about .sec01__text.--fir {
	letter-spacing: 3px;
	line-height: 37px;
}

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

.about .sec01__text.--table {
	font-size: 12px;
	letter-spacing: 2.4px;
	line-height: 31px;
}

.about .sec01__title {
	font-size: 18px;
	letter-spacing: 6.3px;
	line-height: 37px;
}

.about .sec01__title.--lead {
	letter-spacing: 3.6px;
}

.about .sec01__title.--table {
	font-size: 24px;
	letter-spacing: 8.4px;
	line-height: 37px;
	text-align: center;
}

.about .sec01__item {
	align-items: center;
	display: flex;
	gap: 22px;
}

.about .sec01__icon {
	flex-shrink: 0;
	width: 105px;
}

.about .sec01__table {
	border-collapse: separate;
}

.about .sec01__table-th {
	font-size: 10px;
	font-weight: normal;
	letter-spacing: 2px;
	text-align: left;
	vertical-align: top;
	white-space: nowrap;
}

.about .sec01__table-td {
	font-size: 12px;
	letter-spacing: 2.4px;
	line-height: 18px;
	padding-bottom: 11px;
	padding-left: 8px;
}

/* ----------- chef ----------- */

.chef {
	background: url(../img/chef-bg.webp) no-repeat center center/cover;
	padding-bottom: 80px; /* sec01 */ /* sec02 */ /* sec03 */
}

.chef .c-fv {
	background: url(../img/chef-fv.webp) no-repeat center center/cover;
}

.chef .c-fv__heading {
	left: auto;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}

.chef .sec01 {
	padding-top: 52px;
}

.chef .sec01__inner {
	display: flex;
	gap: 30px;
}

.chef .sec01__title {
	font-size: 21px;
	letter-spacing: 5px;
	white-space: nowrap;
	writing-mode: vertical-rl;
}

.chef .sec01__container {
	display: flex;
	flex-direction: column;
	gap: 52px;
}

.chef .sec01__text {
	font-size: 15px;
	letter-spacing: 3px;
	line-height: 29px;
}

.chef .sec01__img-1 {
	width: 275px;
}

.chef .sec02 {
	margin-top: 20px;
}

.chef .sec02__inner {
	display: flex;
	flex-direction: column;
	gap: 53px;
	margin: 0 auto;
	max-width: 500px;
}

.chef .sec02__item {
	display: flex;
	gap: 21px;
	justify-content: space-between;
	padding-inline: 34px 44px;
}

.chef .sec02__img-2 {
	margin-top: 100px;
	width: 180px;
}

.chef .sec02__img-3 {
	width: 161px;
}

.chef .sec02__img-4 {
	width: 359px;
}

.chef .sec03 {
	margin-top: 70px;
}

.chef .sec03__title {
	font-size: 20px;
	letter-spacing: 5px;
	text-align: center;
}

.chef .sec03__container {
	background: #fff;
	border-radius: 9px;
	box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	gap: 21px;
	margin-top: 16px;
	padding: 26px 27px 18px;
}

.chef .sec03__item {
	align-items: center;
	display: flex;
	gap: 12px;
}

.chef .sec03__img {
	flex-shrink: 0;
	width: 170px;
}

.chef .sec03__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.chef .sec03__name {
	font-size: 20px;
	letter-spacing: 2px;
}

.chef .sec03__price {
	font-size: 14px;
	letter-spacing: 4.9px;
}

.chef .sec03__desc {
	font-size: 13px;
	letter-spacing: 2.6px;
	line-height: 27px;
}

.chef .sec03__link {
	align-items: center;
	display: flex;
	gap: 5px;
	justify-content: center;
	transition: 0.3s;
}

.chef .sec03__link:hover {
	opacity: 0.7;
}

.chef .sec03__link:hover .--arrow {
	transform: translateX(4px);
}

.chef .sec03__link-text {
	font-size: 17px;
	letter-spacing: 5.95px;
	line-height: 27px;
	transition: 0.3s;
}

/* ----------- menu ----------- */

.menu {
	padding-bottom: 100px; /* sec02 */
}

.menu__swiper {
	aspect-ratio: 406/274;
	border-radius: 8px;
	height: 274px;
	margin: 0;
	width: 100%;
}

.menu__swiper .swiper-slide .sec02__img {
	aspect-ratio: 406/274;
	border-radius: 0px;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: center;
	object-position: center;
}

.menu__swiper-thumb {
	margin: 0;
}

.menu__swiper-thumb .swiper-wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: 20px 8px;
	justify-content: center;
}

.menu__swiper-thumb .swiper-slide {
	cursor: pointer;
	transition: 0.3s;
	width: calc(50% - 4px);
}

.menu__swiper-thumb .swiper-slide:hover {
	opacity: 0.7;
}

.menu__swiper-thumb .swiper-slide img {
	height: auto;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.menu .c-fv {
	background: url(../img/menu-fv.webp) no-repeat center center/cover;
}

.menu .sec01__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 14px;
	padding-block: 22px 38px;
}

.menu .sec01__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2em;
	width: 100%;
}

.menu .sec01__text {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 28px;
	text-align: center;
}

.menu .sec01 .--button {
	margin-top: 21px;
}

.menu .sec01 .--button .c-button {
	font-size: 12px;
	padding-block: 13px;
}

.menu .sec02 {
	margin-top: 24px;
}

.menu .sec02 .c-tab__head-wrapper {
	border-bottom: 3px solid #b3b3b3;
	display: flex;
}

.menu .sec02 .c-tab__head {
	cursor: pointer;
	padding-bottom: 11px;
	position: relative;
	width: 25%;
}

.menu .sec02 .c-tab__head::after {
	background: transparent;
	bottom: -3px;
	content: "";
	height: 3px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	transition: 0.4s;
	width: 100%;
}

.menu .sec02 .c-tab__head:hover .c-tab__head-text {
	color: #353535;
}

.menu .sec02 .c-tab__head.--active::after {
	background: #353535;
}

.menu .sec02 .c-tab__head.--active .c-tab__head-text {
	color: #353535;
}

.menu .sec02 .c-tab__head-text {
	color: #b3b3b3;
	font-size: 16px;
	text-align: center;
	transition: 0.4s;
}

.menu .sec02 .c-tab__content-wrapper {
	margin-top: 32px;
}

.menu .sec02 .c-tab__content {
	display: none;
	transition: 0.5s;
	width: 100%;
}

.menu .sec02 .c-tab__content.--active {
	align-items: center;
	animation: panel-show 0.9s ease-in-out forwards;
	display: flex;
	flex-direction: column;
	gap: 100px;
}

.menu .sec02 .c-tab__content .sec02__text + .sec02__items {
	margin-top: -50px;
}

.menu .sec02__items {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 50px;
}

.menu .sec02__term {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.menu .sec02__item {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 15px;
}

.menu .sec02__img {
	border-radius: 8px;
	overflow: hidden;
	width: 100%;
}

.menu .sec02__body {
	display: flex;
	flex-direction: column;
	gap: 15px;
	width: 100%;
}

.menu .sec02__title {
	font-size: 18px;
	letter-spacing: 4.68px;
	line-height: 27px;
	text-align: center;
}

.menu .sec02__price {
	font-size: 16px;
	letter-spacing: 5.6px;
	line-height: 27px;
	text-align: center;
}

.menu .sec02__text {
	font-size: 13px;
	letter-spacing: 3.64px;
	line-height: 27px;
	width: 100%;
}

.menu .sec02__text span {
	color: #f04141;
}

.menu .sec02__text-bg {
	background: #2a6fbb;
	color: #fff;
	display: inline-block;
	font-size: 13px;
	letter-spacing: 3.64px;
	line-height: 27px;
	margin-right: auto;
	margin-top: 16px;
	padding: 2px 8px;
	width: -moz-fit-content;
	width: fit-content;
}

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

.menu .sec02__content-title {
	font-size: 25px;
	letter-spacing: 1px;
}

.menu .sec02__content-line {
	background: #353535;
	height: 50px;
	width: 1px;
}

/* ----------- room ----------- */

.room .c-fv {
	background: url(../img/room-fv.webp) no-repeat center center/cover;
}

.room .sec01__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 40px;
	padding-block: 38px;
}

.room .sec01__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2em;
	width: 100%;
}

.room .sec01__text {
	font-size: 15px;
	letter-spacing: 2.8px;
	line-height: 37px;
}

.room .sec01__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 20px;
	width: 100%;
}

.room .sec02 {
	padding-bottom: 80px;
}

.room .sec02__items {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.room .sec02__item {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.room .sec02__body {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.room .sec02__title {
	font-size: 20px;
	letter-spacing: 7px;
	line-height: 27px;
	text-align: center;
}

.room .sec02__text {
	font-size: 14px;
	letter-spacing: 4.9px;
	line-height: 27px;
}

.room .sec02__text a {
	text-decoration: underline;
	transition: 0.3s;
}

.room .sec02__text a:hover {
	opacity: 0.7;
}

.room .sec03 {
	background: #d9ceaf;
	padding-block: 50px;
}

.room .sec03__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.room .sec03__title {
	font-size: 20px;
	letter-spacing: 1px;
	text-align: center;
	width: 100%;
}

.room .sec03__text {
	font-size: 15px;
	letter-spacing: 1px;
	line-height: 2;
	width: 100%;
}

.room .sec03__img {
	width: 100%;
}

/* ----------- rental ----------- */

.rental .c-fv {
	background: url(../img/rental-fv.webp) no-repeat center center/cover;
}

.rental .sec01__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding-block: 38px;
}

.rental .sec01__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2em;
	width: 100%;
}

.rental .sec01__text {
	font-size: 15px;
	letter-spacing: 3px;
	line-height: 37px;
}

.rental .sec01__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 20px;
	width: 100%;
}

.rental .sec02 {
	padding-bottom: 144px;
}

.rental .sec02__items {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.rental .sec02__item {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.rental .sec02__text {
	font-size: 16px;
	letter-spacing: 1px;
}

.rental .sec02__text a {
	text-decoration: underline;
	transition: 0.3s;
}

.rental .sec02__text a:hover {
	opacity: 0.7;
}

.rental .sec03 {
	background: #d9ceaf;
	padding-block: 50px;
}

.rental .sec03__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.rental .sec03__title {
	font-size: 20px;
	letter-spacing: 1px;
	text-align: center;
	width: 100%;
}

.rental .sec03__text {
	font-size: 15px;
	letter-spacing: 1px;
	line-height: 2;
	width: 100%;
}

.rental .sec03__img {
	width: 100%;
}

/* ----------- info ----------- */

.info {
	padding-top: 100px;
}

.info__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 24px;
	padding-bottom: 64px;
}

.info__heading {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.info__title {
	font-size: 20px;
	letter-spacing: 5px;
	line-height: 28px;
	text-align: center;
}

.info__line {
	background: #353535;
	display: block;
	height: 60px;
	width: 1px;
}

.info__items {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 48px;
	width: 100%;
}

.info__entry {
	width: 100%;
}

.info__entry:hover .info__entry-content {
	opacity: 0.7;
	transform: translateX(15px);
}

.info__entry-content {
	display: flex;
	flex-direction: column;
	gap: 8px;
	transition: 0.3s;
}

.info__entry-meta {
	font-size: 16px;
	letter-spacing: 4px;
	line-height: 28px;
}

.info__entry-title {
	display: -webkit-box;
	font-size: 20px;
	letter-spacing: 5px;
	line-height: 28px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
	text-overflow: ellipsis;
}

.info__entry-text {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 3.5px;
	line-height: 28px;
	overflow: hidden;
	text-overflow: ellipsis;
}

.info__pagination {
	display: flex;
	gap: 5px;
	justify-content: center;
	margin-top: 40px;
}

.info__pagination .page-numbers {
	color: #a8a8a8;
	font-size: 18px;
	letter-spacing: 4.5px;
	line-height: 28px;
	padding-inline: 5px;
	transition: 0.3s;
}

.info__pagination .page-numbers:hover {
	color: #353535;
}

.info__pagination .page-numbers.current {
	color: #353535;
}

.info__pagination .prev,
.info__pagination .next {
	color: #353535;
}

.info__pagination .prev:hover,
.info__pagination .next:hover {
	transform: translateX(4px);
}

.info__pagination .prev:hover {
	transform: translateX(-4px);
}

/* ----------- entry ----------- */

.entry {
	animation: fadeInUp 1s ease-out forwards;
	animation-delay: 0.5s;
	display: flex;
	flex-direction: column;
	gap: 50px;
	opacity: 0;
	transform: translateY(10px);
	width: 100%;
}

.entry__head {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.entry__title {
	font-size: 22px;
	letter-spacing: 5px;
	line-height: 28px;
}

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

.entry__meta {
	font-size: 16px;
	letter-spacing: 4px;
	line-height: 28px;
}

.entry__content {
	display: flex;
	flex-direction: column;
	gap: 25px;
	padding-bottom: 50px;
}

.entry__content h1 {
	font-size: 22px;
	letter-spacing: 5px;
	line-height: 28px;
}

.entry__content h2 {
	font-size: 20px;
	letter-spacing: 4px;
	line-height: 26px;
}

.entry__content h3 {
	font-size: 18px;
	letter-spacing: 3.5px;
	line-height: 24px;
}

.entry__content h4 {
	font-size: 16px;
	letter-spacing: 3px;
	line-height: 22px;
}

.entry__content p {
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 3.5px;
	line-height: 28px;
}

.entry__content a {
	text-decoration: underline;
	text-underline-offset: 5px;
	transition: 0.3s;
}

.entry__content a:hover {
	opacity: 0.7;
}

.entry__list {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 20px;
	margin-top: 100px;
	width: 100%;
}

.entry__items {
	display: flex;
	flex-direction: column;
	gap: 16px;
	width: 100%;
}

.entry__item {
	border-bottom: 1px solid #7b725a;
	display: block;
	padding-bottom: 16px;
}

.entry__item:hover .entry__item-content {
	opacity: 0.7;
	transform: translateX(3%);
}

.entry__item-content {
	display: flex;
	flex-direction: column;
	gap: 5px;
	padding-left: 10px;
	transition: 0.3s;
}

.entry__item-text {
	display: -webkit-box;
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 3.5px;
	line-height: 28px;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	overflow: hidden;
	text-overflow: ellipsis;
}

.entry__item-text.--title {
	padding-left: 10px;
}

/* ----------- access ----------- */

.access__container {
	display: flex;
	flex-direction: column;
	gap: 24px;
	padding-block: 88px 48px;
}

.access__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 17px;
}

.access__title {
	font-size: 20px;
	letter-spacing: 4px;
	line-height: 28px;
}

.access__title.--h1 {
	font-size: 24px;
	letter-spacing: 6px;
	line-height: 28px;
}

.access__text {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 28px;
	width: 100%;
}

.access__text.--lead {
	margin-bottom: 4px;
	text-align: center;
}

.access__text a {
	text-decoration: underline;
}

.access__body {
	width: 100%;
}

.access__line {
	background: #000;
	display: block;
	height: 99px;
	margin-top: 8px;
	width: 1px;
}

.access__line.--sec {
	margin-bottom: 8px;
	margin-top: 0;
}

.access__map {
	margin-top: 24px;
}

.access__map iframe {
	height: 448px;
	width: 100%;
}

/* ----------- contact ----------- */

.contact {
	padding-top: 100px; /* sec01 */ /* sec02 */ /* sec03 */ /* sec04 */
}

.contact__inner {
	display: flex;
	flex-direction: column;
	gap: 40px;
	padding-bottom: 100px;
}

.contact__title {
	font-size: 20px;
	letter-spacing: 5px;
	line-height: 28px; /* 140% */
	text-align: center;
}

.contact__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 60px;
	width: 100%;
}

.contact__text01 {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 28px;
}

.contact__text01 a {
	text-decoration: underline;
	transition: 0.3s;
}

.contact__text01 a:hover {
	opacity: 0.7;
}

.contact__text02 {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 22px;
}

.contact__text02 a {
	text-decoration: underline;
	transition: 0.3s;
}

.contact__text02 a:hover {
	opacity: 0.7;
}

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

.contact__text03 {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 22px;
	width: 100%;
}

.contact__text03 a {
	text-decoration: underline;
	transition: 0.3s;
}

.contact__text03 a:hover {
	opacity: 0.7;
}

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

.contact__head {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.contact__line {
	background: #353535;
	display: block;
	height: 99px;
	width: 1px;
}

.contact .sec01 {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 21px;
}

.contact .sec02 {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.contact .sec02__items {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.contact .sec02__item {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.contact .sec02__img {
	flex-shrink: 0;
	width: 296px;
}

.contact .sec02__body {
	display: flex;
	flex-direction: column;
	gap: 20px;
	width: 100%;
}

.contact .sec02__body .contact__text01 {
	font-size: 16px;
	text-align: center;
}

.contact .sec03 {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.contact .sec04 {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

/* ----------- .media-contact ----------- */

.media-contact {
	padding-bottom: 100px;
	padding-top: 100px;
}

.media-contact__head {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.media-contact__title {
	font-size: 20px;
	letter-spacing: 5px;
	line-height: 28px;
	text-align: center;
}

.media-contact__desc {
	font-size: 13px;
	letter-spacing: 3px;
	line-height: 28px;
	line-height: 28px;
}

.media-contact__line {
	background: #353535;
	display: block;
	height: 99px;
	width: 1px;
}

.media-contact__form {
	border: 1px solid #353535;
	margin-top: 30px;
	padding: 30px 20px;
}

.media-contact__form a {
	text-decoration: underline;
	transition: 0.3s;
}

.media-contact__form a:hover {
	opacity: 0.7;
}

.media-contact__form table,
.media-contact__form tbody {
	width: 100%;
}

.media-contact__form tr {
	display: flex;
	flex-direction: column;
	gap: 10px;
	text-align: left;
	width: 100%;
}

.media-contact__form tr + tr {
	margin-top: 20px;
}

.media-contact__form th {
	font-size: 16px;
	letter-spacing: 2px;
	line-height: 28px;
}

.media-contact__form td {
	font-size: 14px;
	letter-spacing: 1px;
	line-height: 28px;
}

.media-contact__form .wpcf7-checkbox {
	display: flex;
	flex-direction: column;
}

.media-contact__form .wpcf7-checkbox .wpcf7-list-item {
	align-items: center;
	display: flex;
	gap: 10px;
}

.media-contact__form .wpcf7-text,
.media-contact__form .wpcf7-textarea {
	border: 1px solid #353535;
	outline: none;
	padding: 5px;
	width: 100%;
}

.media-contact__form a {
	text-decoration: underline;
}

.media-contact__form .wpcf7-acceptance {
	display: inline-block;
	margin-top: 20px;
}

.media-contact__form .wpcf7-submit {
	margin-top: 60px;
}

.media-contact__form .wpcf7-response-output {
	margin-top: 40px;
}

.media-contact__form .screen-reader-response {
	display: none;
}

.media-contact__form .wpcf7-not-valid-tip {
	color: #f00;
}

/* ----------- footer ----------- */

.footer {
	background: #7b725a;
	color: #fff;
	padding-block: 30px;
}

.footer a {
	transition: 0.3s;
}

.footer a:hover {
	opacity: 0.7;
}

.footer__inner {
	align-items: center;
	display: flex;
	flex-direction: column;
}

.footer__logo {
	display: block;
	width: 100px;
}

.footer__sns {
	align-items: center;
	display: flex;
	gap: 16px;
	justify-content: center;
	margin-top: 20px;
}

.footer__icon {
	display: block;
	width: 27px;
}

.footer__content {
	display: flex;
	flex-direction: column;
	gap: 1em;
	margin-top: 30px;
	width: 100%;
}

.footer__text {
	font-size: 12px;
	letter-spacing: 4.2px;
	line-height: 15px;
}

.footer__text.--copy {
	margin-top: 30px;
	width: 100%;
}

.footer__block { /* floating格納用 */
	height: 74px;
}

.floating {
	align-items: center;
	background: #2a6fbb;
	bottom: 0;
	color: #fff;
	display: flex;
	font-size: 12px;
	font-weight: 400;
	justify-content: center;
	left: 0;
	letter-spacing: 4.2px;
	line-height: 14px;
	opacity: 0;
	padding: 30px;
	pointer-events: none;
	position: fixed;
	text-align: center;
	transition: 0.3s;
	width: 100%;
	z-index: 79;
}

.floating.--visible {
	opacity: 1;
	pointer-events: all;
}

.floating:hover {
	background: #5688be;
}

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

.header.--bk {
	-webkit-backdrop-filter: blur(0px);
	backdrop-filter: blur(0px);
	background-color: transparent;
}

.header__inner {
	padding-block: 32px;
}

.header__logo {
	width: 137px;
}

.g-nav {
	min-width: 323px;
	width: 30%;
}

.index .hero__title {
	font-size: 18px;
	left: 50%;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.3137254902), 0 0 10px rgba(0, 0, 0, 0.3137254902), 0 0 10px rgba(0, 0, 0, 0.3137254902);
	transform: translate(-50%, -50%);
}

.index .hero__logo {
	top: 44%;
	width: 140px;
}

.index .sec01__inner {
	padding-block: 50px;
}

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

.index .sec02__content {
	gap: 60px;
	right: 60px;
}

.index .sec02__title {
	font-size: 37px;
	letter-spacing: 5px;
	line-height: 41px;
}

.index .sec02__arrow {
	transform: translateX(-85.27%);
}

.index .sec04__items {
	gap: 27px;
	margin-top: 39px;
}

.index .sec04__item {
	padding-bottom: 20px;
}

.index .sec04__item:hover .sec04__item-content {
	transform: translateX(1%);
}

.index .sec04__item-content {
	gap: 20px;
	padding-left: 7%;
}

.index .sec04__item-meta {
	font-size: 12px;
	letter-spacing: 1.2px;
	line-height: 17px;
}

.index .sec04__item-title {
	padding-left: 16%;
}

.p-shop__title {
	font-size: 30px;
	letter-spacing: 10.5px;
}

.p-shop__desc {
	font-size: 17px;
	letter-spacing: 3.91px;
}

.p-shop__img {
	width: 300px;
}

.p-shop__item-container {
	display: flex;
	flex-direction: row-reverse;
	flex-wrap: wrap;
	max-width: 1200px;
}

.p-shop__item.--fir {
	margin-inline: auto 0;
	width: 320px;
}

.p-shop__item.--sec {
	margin-top: 150px;
	width: 357px;
}

.p-shop__item.--sar {
	margin-inline: auto;
	width: 600px;
}

.about .sec01 {
	padding-block: 45px 100px;
}

.about .sec01__container {
	gap: 64px;
}

.about .sec01__content {
	gap: 30px;
}

.about .sec01__text {
	letter-spacing: 3px;
	line-height: 31px;
}

.about .sec01__text.--fir {
	letter-spacing: 3.6px;
	line-height: 37px;
}

.about .sec01__text.--table {
	font-size: 15px;
	letter-spacing: 3px;
	line-height: 31px;
	text-align: center;
}

.about .sec01__body {
	display: flex;
	flex-direction: column;
	gap: 27px;
}

.about .sec01__title {
	font-size: 24px;
	line-height: 37px;
	text-align: center;
}

.about .sec01__title.--lead {
	text-align: left;
}

.about .sec01__icon {
	width: 170px;
}

.about .sec01__table-th {
	font-size: 12px;
	letter-spacing: 2.4px;
	line-height: 31px;
}

.about .sec01__table-td {
	font-size: 15px;
	letter-spacing: 3px;
	line-height: 31px;
	padding-bottom: 12px;
	padding-left: 65px;
}

.chef .sec01__title {
	font-size: 47px;
}

.chef .sec01__text {
	font-size: 20px;
	letter-spacing: 7px;
	padding-left: 31px;
}

.chef .sec01__img-1 {
	width: 578px;
}

.chef .sec02__inner {
	max-width: 973px;
}

.chef .sec02__img-2 {
	width: 449px;
}

.chef .sec02__img-3 {
	width: 290px;
}

.chef .sec02__img-4 {
	margin-left: auto;
	width: 672px;
}

.chef .sec03 {
	margin-top: 114px;
}

.chef .sec03__title {
	font-size: 32px;
}

.chef .sec03__container {
	gap: 71px;
	margin-top: 51px;
	padding: 50px 44px 45px;
}

.chef .sec03__item {
	align-items: start;
	gap: 60px;
}

.chef .sec03__img {
	width: 277px;
}

.chef .sec03__head {
	gap: 30px;
}

.chef .sec03__name {
	font-size: 28px;
}

.chef .sec03__price {
	font-size: 20px;
}

.chef .sec03__desc {
	font-size: 15px;
	letter-spacing: 3px;
}

.menu__swiper {
	flex-shrink: 0;
	height: auto;
	max-width: 506px;
	width: 50%;
}

.menu__swiper-thumb .swiper-wrapper {
	gap: 16px 10px;
	justify-content: start;
}

.menu__swiper-thumb .swiper-slide {
	width: 160px;
}

.menu .sec01__inner {
	padding-block: 50px;
}

.menu .sec01__text {
	font-size: 15px;
	letter-spacing: 3.75px;
}

.menu .sec01 .--button {
	margin-top: 41px;
}

.menu .sec01 .--button .c-button {
	font-size: 14px;
	padding-block: 18px;
}

.menu .sec02 {
	margin-top: 90px;
}

.menu .sec02 .c-tab__head-text {
	font-size: 20px;
}

.menu .sec02 .c-tab__content-wrapper {
	margin-top: 100px;
	padding-inline: 30px;
}

.menu .sec02 .c-tab__content .sec02__text + .sec02__items {
	margin-top: 0;
}

.menu .sec02__items {
	gap: 100px;
	width: 100%;
}

.menu .sec02__term {
	gap: 10px;
}

.menu .sec02__item {
	align-items: start;
	flex-direction: row;
	gap: 44px;
	justify-content: space-between;
	width: 100%;
}

.menu .sec02__img {
	flex-shrink: 0;
	max-width: 506px;
	width: 50%;
}

.menu .sec02__body {
	gap: 20px;
}

.menu .sec02__title {
	font-size: 25px;
	letter-spacing: 6.5px;
	line-height: 1.5;
	text-align: left;
}

.menu .sec02__price {
	font-size: 18px;
	letter-spacing: 6.3px;
	text-align: left;
}

.menu .sec02__text {
	color: #353535;
	font-size: 15px;
	letter-spacing: 4.2px;
	line-height: 27px;
	width: -moz-fit-content;
	width: fit-content;
}

.menu .sec02__text-bg {
	font-size: 15px;
	letter-spacing: 4.2px;
	margin-top: 37px;
}

.room .sec01__inner {
	gap: 80px;
	padding-block: 50px;
}

.room .sec01__text {
	font-size: 18px;
	letter-spacing: 3.1px;
	line-height: 37px;
}

.room .sec02 {
	padding-bottom: 148px;
}

.room .sec02__items {
	gap: 70px;
}

.room .sec02__item {
	gap: 44px;
}

.room .sec02__body {
	gap: 20px;
	margin: 0 auto;
	max-width: 639px;
}

.room .sec02__text {
	font-size: 14px;
	letter-spacing: 4.9px;
	line-height: 27px;
}

.room .sec03__text {
	letter-spacing: 5.25px;
	line-height: 29px;
	text-align: center;
}

.room .sec03__img {
	margin-top: 20px;
}

.rental .sec01__inner {
	gap: 68px;
	padding-block: 50px;
}

.rental .sec01__text {
	font-size: 20px;
	letter-spacing: 4px;
}

.rental .sec02__items {
	gap: 70px;
}

.rental .sec02__item {
	gap: 44px;
}

.rental .sec02__body {
	margin: 0 auto;
	max-width: 639px;
}

.rental .sec02__text {
	letter-spacing: 5.6px;
	line-height: 31px;
}

.rental .sec03__text {
	letter-spacing: 5.25px;
	line-height: 29px;
}

.info__title {
	font-size: 24px;
}

.info__line {
	height: 99px;
}

.info__entry-meta {
	font-size: 20px;
}

.info__entry-title {
	font-size: 22px;
}

.info__entry-text {
	font-size: 15px;
}

.entry__title {
	font-size: 24px;
}

.entry__meta {
	font-size: 20px;
}

.entry__content h1 {
	font-size: 24px;
}

.entry__content h2 {
	font-size: 22px;
}

.entry__content h3 {
	font-size: 20px;
}

.entry__content h4 {
	font-size: 18px;
}

.entry__content p {
	font-size: 16px;
}

.entry__list .info__line {
	height: 60px;
}

.entry__item:hover .entry__item-content {
	transform: translateX(1%);
}

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

.access__container {
	gap: 50px;
	padding-block: 200px 100px;
}

.access__content {
	gap: 20px;
}

.access__title {
	font-size: 24px;
	letter-spacing: 6px;
	line-height: 28px;
}

.access__text.--lead {
	margin: 0;
}

.access__text {
	font-size: 16px;
	letter-spacing: 4px;
}

.access__line {
	margin-top: 30px;
}

.access__line.--sec {
	margin-bottom: 30px;
}

.contact {
	padding-top: 200px;
}

.contact__title {
	font-size: 24px;
}

.contact__content {
	gap: 50px;
}

.contact__text01 {
	width: -moz-fit-content;
	width: fit-content;
}

.contact__text02 {
	line-height: 28px;
	width: -moz-fit-content;
	width: fit-content;
}

.contact__text03 {
	width: -moz-fit-content;
	width: fit-content;
}

.contact__head {
	gap: 50px;
}

.contact .sec02 {
	gap: 50px;
}

.contact .sec02__items {
	gap: 64px;
	max-width: 800px;
}

.contact .sec02__item {
	flex-direction: row;
	gap: 30px;
}

.contact .sec02__body .contact__text01 {
	text-align: left;
}

.contact .sec03 {
	gap: 50px;
}

.contact .sec04 {
	gap: 50px;
	margin-top: 50px;
}

.media-contact__head {
	gap: 50px;
}

.media-contact__title {
	font-size: 24px;
}

.media-contact__desc {
	font-size: 16px;
	letter-spacing: 4px;
	line-height: 28px;
}

.media-contact__form {
	font-size: 13px;
	letter-spacing: 3.25px;
	line-height: 20px;
	margin-top: 50px;
	padding: 30px 60px;
}

.media-contact__form tr + tr {
	margin-top: 30px;
}

.media-contact__form th {
	font-size: 18px;
}

.media-contact__form td {
	font-size: 16px;
}

.media-contact__form .wpcf7-checkbox {
	gap: 5px;
}

.footer {
	padding-block: 40px;
}

.footer__logo {
	width: 158px;
}

.footer__sns {
	gap: 26px;
}

.footer__icon {
	width: 47px;
}

.footer__content {
	margin-top: 47px;
	text-align: center;
}

.footer__text span {
	display: inline;
}

.footer__text.--copy {
	font-size: 12px;
	letter-spacing: 4.2px;
	line-height: 15px;
	margin-top: 54px;
	text-align: center;
}

.floating {
	font-size: 20px;
}

}

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

.header__wrap {
	padding-inline: 75px;
}

}

