/* ==========================================================================
   コースセクション共通
   ========================================================================== */
.menu-course {
	padding: 80px 0;
}

.menu-course:nth-child(even) {
	background-color: var(--color-white);
}

.menu-course:nth-child(odd) {
	background-color: var(--color-ivory);
}

.menu-course__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 56px;
	align-items: start;
}

.menu-course__inner--reverse {
	direction: rtl;
}

.menu-course__inner--reverse > * {
	direction: ltr;
}

/* 画像 */
.menu-course__image {
	overflow: hidden;
}

.menu-course__image img {
	width: 100%;
	height: 380px;
	object-fit: cover;
	transition: transform 0.6s;
}

.menu-course__image:hover img {
	transform: scale(1.03);
}

/* バッジ */
.menu-course__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	font-size: 1.25rem;
	font-weight: 700;
	border-radius: 50%;
	margin-bottom: 16px;
}

.menu-course__badge--matsu {
	background-color: var(--color-gold);
	color: var(--color-white);
}

.menu-course__badge--take {
	background-color: var(--color-ai);
	color: var(--color-gold-light);
}

.menu-course__badge--ume {
	background-color: var(--color-sumi);
	color: var(--color-gold-light);
}

/* テキスト */
.menu-course__name {
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: 0.15em;
	color: var(--color-sumi);
}

.menu-course__price {
	font-size: 0.9375rem;
	color: var(--color-sumi);
	margin-top: 12px;
	letter-spacing: 0.05em;
}

.menu-course__price strong {
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-ai);
}

.menu-course__price span {
	font-size: 0.8125rem;
}

.menu-course__desc {
	font-size: 0.9375rem;
	line-height: 2;
	margin-top: 16px;
	color: var(--color-sumi);
}

.menu-course__line {
	width: 40px;
	height: 1px;
	background-color: var(--color-gold);
	margin: 24px 0;
}

/* 品目一覧 */
.menu-course__items {
	border-top: 1px solid var(--color-border);
}

.menu-course__items-row {
	display: flex;
	gap: 16px;
	padding: 10px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 0.875rem;
	line-height: 1.6;
}

.menu-course__items-row dt {
	flex-shrink: 0;
	width: 5em;
	font-weight: 500;
	color: var(--color-ai);
}

.menu-course__items-row dd {
	color: var(--color-sumi);
}

.menu-course__note {
	font-size: 0.75rem;
	color: #888;
	margin-top: 16px;
}

/* SP */
@media (max-width: 767px) {
	.menu-course {
		padding: 56px 0;
	}

	.menu-course__inner,
	.menu-course__inner--reverse {
		grid-template-columns: 1fr;
		gap: 32px;
		direction: ltr;
	}

	.menu-course__image img {
		height: 240px;
	}

	.menu-course__name {
		font-size: 1.25rem;
	}

	.menu-course__price strong {
		font-size: 1.5rem;
	}
}

/* ==========================================================================
   季節のおすすめ
   ========================================================================== */
.seasonal {
	padding: 96px 0;
	background-color: var(--color-white);
}

.seasonal__lead {
	text-align: center;
	font-size: 0.9375rem;
	line-height: 2;
	color: var(--color-sumi);
	margin-bottom: 48px;
}

.seasonal__list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}

.seasonal__item {
	background-color: var(--color-ivory);
	border: 1px solid var(--color-border);
	transition: box-shadow 0.3s, transform 0.3s;
}

.seasonal__item:hover {
	box-shadow: 0 8px 24px rgba(43, 43, 43, 0.1);
	transform: translateY(-4px);
}

/* 画像 + 季節バッジ */
.seasonal__item-image {
	position: relative;
	overflow: hidden;
}

.seasonal__item-image img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	transition: transform 0.6s;
}

.seasonal__item:hover .seasonal__item-image img {
	transform: scale(1.05);
}

.seasonal__item-season {
	position: absolute;
	top: 12px;
	left: 12px;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	background-color: var(--color-ai);
	color: var(--color-gold);
	font-size: 0.8125rem;
	font-weight: 700;
	border-radius: 50%;
}

/* テキスト */
.seasonal__item-body {
	padding: 20px;
}

.seasonal__item-name {
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	color: var(--color-sumi);
	margin-bottom: 8px;
}

.seasonal__item-desc {
	font-size: 0.8125rem;
	line-height: 1.8;
	color: #666;
}

/* SP */
@media (max-width: 767px) {
	.seasonal {
		padding: 64px 0;
	}

	.seasonal__list {
		grid-template-columns: 1fr 1fr;
		gap: 16px;
	}

	.seasonal__item-image img {
		height: 140px;
	}

	.seasonal__item-body {
		padding: 16px;
	}

	.seasonal__item-name {
		font-size: 0.875rem;
	}
}

@media (max-width: 480px) {
	.seasonal__list {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   CTA ボタン並び
   ========================================================================== */
.cta-section__buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

/* ==========================================================================
   ライトボックス用カーソル
   ========================================================================== */
.js-lightbox-trigger {
	cursor: zoom-in;
}

/* ==========================================================================
   ライトボックス
   ========================================================================== */
.lightbox {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2000;
	background-color: rgba(43, 43, 43, 0.92);
	justify-content: center;
	align-items: center;
	padding: 40px;
	cursor: zoom-out;
}

.lightbox[aria-hidden="false"] {
	display: flex;
	animation: lightboxFadeIn 0.3s ease;
}

@keyframes lightboxFadeIn {
	from { opacity: 0; }
	to   { opacity: 1; }
}

.lightbox__close {
	position: absolute;
	top: 20px;
	right: 24px;
	background: none;
	border: none;
	color: var(--color-gold);
	font-size: 2.5rem;
	line-height: 1;
	cursor: pointer;
	transition: opacity 0.3s;
	z-index: 2001;
}

.lightbox__close:hover {
	opacity: 0.7;
}

.lightbox__body {
	max-width: 900px;
	max-height: 80vh;
}

.lightbox__img {
	display: block;
	max-width: 100%;
	max-height: 80vh;
	object-fit: contain;
	cursor: default;
}

/* SP: ライトボックス全画面表示 */
@media (max-width: 767px) {
	.lightbox {
		padding: 0;
		background-color: rgba(0, 0, 0, 0.95);
	}

	.lightbox__close {
		top: 12px;
		right: 12px;
		width: 48px;
		height: 48px;
		font-size: 2rem;
		display: flex;
		align-items: center;
		justify-content: center;
		background-color: rgba(27, 58, 92, 0.8);
		border-radius: 50%;
	}

	.lightbox__body {
		width: 100%;
		height: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
		max-height: none;
	}

	.lightbox__img {
		width: 100%;
		height: 100%;
		max-height: 100vh;
		object-fit: contain;
	}
}
