/* ======================================================
   ジャンルで探す ページ (genre.css)
   ====================================================== */

.km-pageHero--genre {
	background: linear-gradient(160deg, var(--km-bg) 60%, #FFF3DC 100%);
}

/* 検索パネルの余白調整 */
.km-searchSection {
	padding: 48px 0 24px;
}

/* ジャンルページの検索セクション: ベージュは内側コンテナだけに適用 */
.km-page-genre .km-searchSection {
	background: var(--km-white);
}

.km-page-genre .km-searchSection .km-container {
	background: transparent;
}

.km-page-genre #km-searchPanel-genre.km-searchPanel__inner--genre {
	background: var(--km-bg);
	border-radius: 18px;
	padding: 24px 20px;
}

/* ジャンルアイコンカードの白背景を除去 */
.km-page-genre .km-genreItem {
	background: transparent;
	border-radius: 0;
	box-shadow: none;
}

.km-page-genre .km-genreItem:hover {
	box-shadow: none;
}

/* ジャンルごとのオススメ */
.km-genreRecommend:not(.km-genreRecommend--shared) {
	margin-top: 24px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 20px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__col {
	background: var(--km-white);
	border-radius: 16px;
	padding: 16px 18px 14px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
	border: 1px solid rgba(0, 0, 0, 0.04);
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__header {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 6px 18px;
	background: var(--km-accent);
	color: var(--km-white);
	font-weight: 800;
	font-size: 15px;
	border-radius: 999px;
	margin-bottom: 12px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 8px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__item a {
	display: flex;
	align-items: center;
	gap: 10px;
	text-decoration: none;
	color: var(--km-text);
	font-weight: 700;
	font-size: 15px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__itemTitle {
	font-size: 16px;
	line-height: 1.4;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__trophy {
	font-size: 20px;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__trophy--gold {
	color: #f6c350;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__trophy--silver {
	color: #c8c8c8;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__trophy--bronze {
	color: #d58c5b;
}

.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__empty {
	font-size: 14px;
	color: #9b958c;
	font-weight: 600;
}

/* 選択中グループラベルが白背景で消えないように補正 */
.km-searchSection .km-genreFilter.is-active {
	background: #F3C94A;
	color: #4d4132;
	outline-color: #E4B72A;
	box-shadow: 0 6px 14px rgba(228, 183, 42, 0.24);
}

.km-searchSection .km-genreFilter.is-active:hover {
	background: #F0C137;
	outline-color: #D9A91B;
}

/* レスポンシブ */
@media (max-width: 1024px) {
	.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 640px) {
	.km-searchSection {
		padding: 36px 0 16px;
	}

	.km-page-genre #km-searchPanel-genre.km-searchPanel__inner--genre {
		padding: 16px 14px;
		border-radius: 14px;
	}

	.km-genreRecommend:not(.km-genreRecommend--shared) .km-genreRecommend__grid {
		grid-template-columns: 1fr;
	}
}

/* ジャンルページ モバイルヒーロー: 三重県マップを右側に表示 */
@media (max-width: 640px) {
	.km-page-genre .km-nonTopHero--page {
		min-height: 220px;
	}

	.km-page-genre .km-nonTopHero__mieMap {
		position: absolute;
		right: -8px;
		top: 50%;
		transform: translateY(-40%);
		height: auto;
		width: 56%;
		max-height: none;
		margin: 0;
		opacity: 0.82;
	}
}
