/* ----- body ----- */

body {
	color: #333333;
	font-family: "Noto Serif JP", serif;
	font-feature-settings: "palt" 1;
}

/* ----- wrapper ----- */

.c-wrap920 {
	margin-inline: auto;
	max-width: min(calc(920 / 1440 * 100vw), 920px);
	width: 100%;
}

.c-wrap1000 {
	margin-inline: auto;
	max-width: min(calc(1000 / 1440 * 100vw), 1000px);
	width: 100%;
}

.c-wrap1200 {
	margin-inline: auto;
	max-width: min(calc(1200 / 1440 * 100vw), 1200px);
	width: 100%;
}

/* -----  ----- */

picture {
	display: block;
}

img {
	width: 100%;
}

/* -----  ----- */

.s-of-hidden {
	overflow: hidden;
}

.tx-red {
	color: #db3b48;
}

.sp {
	display: none;
}

.pc {
	display: block;
}

/* -----  ----- */

.c-heading {
	align-items: center;
	display: flex;
	flex-direction: column;
	line-height: 1;
}

.c-heading.--st {
	align-items: start;
}

.c-heading__en {
	color: #b49531;
	font-family: "Amiri", serif;
	font-size: min(calc(60 / 1440 * 100vw), 60px);
	letter-spacing: 0.03em;
}

.c-heading__en.--white {
	color: #fff;
	font-size: min(calc(50 / 1440 * 100vw), 50px);
}

.c-heading__en.--small {
	font-size: min(calc(50 / 1440 * 100vw), 50px);
}

.c-heading__ja {
	color: #9a9a9a;
	font-size: min(calc(18 / 1440 * 100vw), 18px);
}

.c-heading__ja.--white {
	color: #fff;
}

.c-heading__ja.--fv {
	color: #b49531;
	font-size: min(calc(22 / 1440 * 100vw), 22px);
}

.c-button {
	align-items: center;
	background: #333333;
	color: #fff;
	display: flex;
	font-family: "Amiri", serif;
	font-size: min(calc(22 / 1440 * 100vw), 22px);
	justify-content: center;
	letter-spacing: 0.03em;
	padding: min(calc(20 / 1440 * 100vw), 20px);
	position: relative;
	transition: all 0.3s ease;
	width: min(calc(360 / 1440 * 100vw), 360px);
}

.c-button.--ja {
	font-family: "Noto Serif JP", serif;
}

.c-button::after {
	background: currentColor;
	content: "";
	height: min(calc(1 / 1440 * 100vw), 1px);
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: background-color 0.3s ease;
	width: min(calc(40 / 1440 * 100vw), 40px);
}

.c-button:hover {
	background: #b49531;
	color: #fff;
}

.c-button:hover svg path {
	stroke: currentColor;
	transition: stroke 0.3s ease;
}

.c-button.--form {
	background: #4a4a4a;
	border: min(calc(1 / 1440 * 100vw), 1px) solid #fff;
	font-weight: 200;
	gap: min(calc(14 / 1440 * 100vw), 14px);
	transition: all 0.3s ease;
}

.c-button.--form:hover {
	background: #fff;
	border-color: #4a4a4a;
	color: #4a4a4a;
}

.c-button.--form:hover svg path {
	stroke: currentColor;
}

.c-button__icon.--form {
	display: block;
	width: min(calc(22 / 1440 * 100vw), 22px);
}

.c-button__icon.--form svg path {
	transition: stroke 0.3s ease;
	stroke: currentColor;
}

.c-button__text.--form {
	font-family: "Noto Serif JP", serif;
	font-size: min(calc(20 / 1440 * 100vw), 20px);
	letter-spacing: 0.05em;
}

.c-breadcrumb {
	align-items: center;
	bottom: min(calc(10 / 1440 * 100vw), 10px);
	display: flex;
	flex-shrink: 0;
	gap: min(calc(12 / 1440 * 100vw), 12px);
	left: 50%;
	max-width: min(calc(1200 / 1440 * 100vw), 1200px);
	position: absolute;
	transform: translateX(-50%);
	width: 83%;
}

.c-breadcrumb__text {
	display: -webkit-box;
	font-family: "Noto Serif JP", serif;
	font-size: min(calc(16 / 1440 * 100vw), 16px);
	letter-spacing: 0.05em;
	white-space: nowrap;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	overflow: hidden;
	text-overflow: ellipsis;
}

.c-pagination {
	display: flex;
	gap: min(calc(17 / 1440 * 100vw), 17px);
	justify-content: center;
}

.c-pagination .swiper-pagination-bullet {
	background: #fff;
	height: min(calc(14 / 1440 * 100vw), 14px);
	margin: 0 !important;
	opacity: 0.4;
	width: min(calc(14 / 1440 * 100vw), 14px);
}

.c-pagination .swiper-pagination-bullet-active {
	background: #fff;
	opacity: 1;
}

.s-op-hover {
	transition: 0.3s;
}

.s-op-hover:hover {
	opacity: 0.7;
}

.s-tx-hover {
	color: inherit;
	display: inline-block;
	position: relative;
	text-decoration: none;
}

.s-tx-hover::after {
	background-color: #fff;
	bottom: max(calc(-2 / 1440 * 100vw), -2px);
	content: "";
	height: min(calc(1 / 1440 * 100vw), 1px);
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	transition: 0.3s ease;
	width: 0;
}

.s-tx-hover:hover::after {
	width: 100%;
}

.--main .s-tx-hover::after {
	background-color: #b49531;
}

.footer-content .s-tx-hover::after {
	background-color: #b49531;
}

.inview_re {
	opacity: 0;
	transform: translateY(10px);
	transition: 1s;
}

.inview_re.is-show {
	opacity: 1;
	transform: translateY(0px);
}

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

.c-wrap920 {
	max-width: 100%;
	padding: 0 40px;
}

.c-wrap1000 {
	max-width: 100%;
	padding: 0 40px;
}

.c-wrap1200 {
	max-width: 100%;
	padding: 0 40px;
}

.sp {
	display: block;
}

.pc {
	display: none;
}

.c-heading__en {
	font-size: calc(30 / 375 * 100vw);
	text-align: center;
}

.c-heading__en.--white {
	font-size: calc(30 / 375 * 100vw);
}

.c-heading__en.--small {
	font-size: calc(30 / 375 * 100vw);
}

.c-heading__ja {
	font-size: calc(14 / 375 * 100vw);
}

.c-heading__ja.--fv {
	font-size: calc(16 / 375 * 100vw);
}

.c-button {
	font-size: calc(14 / 375 * 100vw);
	padding: calc(10 / 375 * 100vw);
	width: calc(220 / 375 * 100vw);
}

.c-button::after {
	height: calc(1 / 375 * 100vw);
	width: calc(30 / 375 * 100vw);
}

.c-button.--form {
	border: calc(1 / 375 * 100vw) solid #fff;
	gap: calc(14 / 375 * 100vw);
}

.c-button__icon.--form {
	width: calc(20 / 375 * 100vw);
}

.c-button__text.--form {
	font-size: calc(16 / 375 * 100vw);
}

.c-breadcrumb {
	bottom: calc(5 / 375 * 100vw);
	gap: calc(12 / 375 * 100vw);
	max-width: none;
	padding-inline: 40px;
	width: 100%;
}

.c-breadcrumb__text {
	font-size: calc(12 / 375 * 100vw);
}

.c-pagination {
	gap: calc(8 / 375 * 100vw);
}

.c-pagination .swiper-pagination-bullet {
	height: calc(6 / 375 * 100vw);
	width: calc(6 / 375 * 100vw);
}

.s-tx-hover::after {
	bottom: calc(-2 / 375 * 100vw);
	height: calc(1 / 375 * 100vw);
}

}

