@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.1
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* ============================================================
   Night Archive — single-shop.php
   ============================================================ */
.na-shop { max-width: 880px; margin: 0 auto; padding: 1rem; }

.na-shop__head { margin-bottom: 1.5rem; }
.na-shop__title { font-size: 1.6rem; font-weight: 700; line-height: 1.35; margin: 0 0 0.8rem; }
.na-shop__thumb img { width: 100%; height: auto; border-radius: 12px; }

.na-shop__h2 {
	font-size: 1.2rem; font-weight: 700; margin: 3rem 0 1rem;
	padding-left: 0.6rem; border-left: 4px solid #d44a72;
}
.na-shop__memo, .na-shop__body, .na-shop__tags, .na-shop__cta-block { margin-bottom: 2.5rem; }

/* サマリーカード（ロゴ・料金・時間 + 公式CTA） */
.na-shop__summary {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 1rem 1.2rem; margin: 1rem 0 2rem;
}
.na-shop__summary-top {
	display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;
}
.na-shop__logo {
	flex: 0 0 auto;
	width: 80px; height: 80px;
	background: #fff; border: 1px solid #eee; border-radius: 12px;
	display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.na-shop__logo img {
	max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain;
}
.na-shop__summary-list {
	flex: 1 1 auto;
	display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem;
	margin: 0;
}
.na-shop__summary-item { display: flex; flex-direction: column; gap: 0.2rem; margin: 0; }
.na-shop__summary-item dt { font-size: 0.8rem; color: #888; margin: 0; }
.na-shop__summary-item dd { font-size: 1.1rem; font-weight: 700; margin: 0; }
.na-shop__price-note { display: inline-block; margin-left: 0.2rem; font-size: 0.78rem; font-weight: 500; color: #888; }

/* タグチップ */
.na-shop__tagmap { margin: 0; }
.na-shop__tagrow {
	display: grid; grid-template-columns: 7rem 1fr; gap: 0.6rem;
	padding: 0.5rem 0; border-bottom: 1px dashed #eee; margin: 0;
}
.na-shop__tagrow dt { font-size: 0.85rem; color: #666; margin: 0; padding-top: 0.2rem; }
.na-shop__tagrow dd { display: flex; flex-wrap: wrap; gap: 0.35rem; margin: 0; }
.na-shop__chip {
	display: inline-block; padding: 0.2rem 0.7rem; font-size: 0.82rem;
	background: #f1f3f6; color: #333; border-radius: 999px;
	border: 1px solid #e3e6ec;
}

/* 編集メモ: SWELLネイティブのキャプションボックス (swell-block-capbox) を利用するためCSS削除 */

/* CTAボタン */
.na-shop__cta {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 220px; padding: 0.85rem 1.4rem; border-radius: 999px;
	font-weight: 700; text-decoration: none; transition: 0.15s;
}
.na-shop__cta--official { background: #d44a72; color: #fff; }
.na-shop__cta--official:hover { background: #b53d61; color: #fff; }
.na-shop__cta--affiliate { background: #fff; color: #d44a72; border: 2px solid #d44a72; }
.na-shop__cta--affiliate:hover { background: #fbeaef; }

.na-shop__cta-list { display: flex; flex-wrap: wrap; gap: 0.8rem; }

/* ============================================================
   v2: ヒーロー / ハイライト / 向き不向き / 詳細折りたたみ
   ============================================================ */

/* ヒーロー */
.na-shop__hero { margin-bottom: 2.5rem; }
.na-shop__hero-head {
	display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem;
}
.na-shop__hero-title { flex: 1 1 auto; min-width: 0; }
.na-shop__hero-area {
	font-size: 0.9rem; color: #666; margin-bottom: 0.3rem;
}
.na-shop__hero-meta {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.8rem;
	margin: 1.2rem 0;
}
.na-shop__meta-card {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 0.9rem 1rem; text-align: center;
}
.na-shop__meta-label { font-size: 0.8rem; color: #888; margin-bottom: 0.3rem; }
.na-shop__meta-value { font-size: 1.4rem; font-weight: 700; color: #222; line-height: 1.2; }
.na-shop__meta-value--text { font-size: 1.1rem; }
.na-shop__meta-unit { font-size: 0.85rem; font-weight: 500; color: #666; margin-left: 0.1rem; }
.na-shop__meta-sub { font-size: 0.75rem; color: #888; margin-top: 0.2rem; }

.na-shop__cta--hero { margin-top: 0.5rem; }

/* 主要ハイライト */
.na-shop__highlights { margin-bottom: 2.5rem; }
.na-shop__highlight-grid {
	display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.8rem;
}
.na-shop__highlight-card {
	background: #fff; border: 1px solid #e3e6ec; border-left: 4px solid #d44a72;
	border-radius: 8px; padding: 0.8rem 1rem;
}
.na-shop__highlight-label { font-size: 0.78rem; color: #888; margin-bottom: 0.25rem; }
.na-shop__highlight-value { font-size: 1rem; font-weight: 700; color: #222; line-height: 1.4; }

/* 向き不向き */
.na-shop__fit { margin-bottom: 2.5rem; }
.na-shop__fit-grid {
	display: grid; grid-template-columns: 1fr 1fr; gap: 1rem;
}
.na-shop__fit-col {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 1rem 1.2rem;
}
.na-shop__fit-col--for { border-color: #cfe8d4; background: #f4fbf6; }
.na-shop__fit-col--not { border-color: #f1d4d4; background: #fdf6f6; }
.na-shop__fit-head { font-weight: 700; margin-bottom: 0.6rem; font-size: 1rem; }
.na-shop__fit-list { margin: 0; padding-left: 1.2rem; }
.na-shop__fit-list li { margin: 0.3rem 0; line-height: 1.6; }

/* 詳細折りたたみ */
.na-shop__details {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 0.8rem 1.2rem;
}
.na-shop__details summary {
	cursor: pointer; font-weight: 700; padding: 0.4rem 0;
	list-style: none; position: relative; padding-right: 2rem;
}
.na-shop__details summary::-webkit-details-marker { display: none; }
.na-shop__details summary::after {
	content: "▼"; position: absolute; right: 0; top: 50%;
	transform: translateY(-50%); font-size: 0.8rem; color: #888;
	transition: transform 0.2s;
}
.na-shop__details[open] summary::after { transform: translateY(-50%) rotate(180deg); }
.na-shop__details .na-shop__tagmap { margin-top: 0.8rem; }

/* スマホ */
@media (max-width: 600px) {
	.na-shop__title { font-size: 1.35rem; }
	.na-shop__tagrow { grid-template-columns: 5.5rem 1fr; }
	.na-shop__cta { min-width: 100%; }
	.na-shop__logo { width: 64px; height: 64px; }
	.na-shop__hero-meta { grid-template-columns: 1fr 1fr; }
	.na-shop__highlight-grid { grid-template-columns: 1fr; }
	.na-shop__fit-grid { grid-template-columns: 1fr; }
	.na-shop__meta-value { font-size: 1.2rem; }
}

/* ============================================================
   Night Archive — front-page.php (TOP)
   ============================================================ */
.na-top { max-width: 1080px; margin: 0 auto; padding: 1rem; }

/* ヒーロー */
.na-top__hero {
	background: linear-gradient(135deg, #d44a72 0%, #8e3858 100%);
	color: #fff; padding: 3rem 1.5rem; border-radius: 16px; text-align: center;
	margin-bottom: 3rem;
}
.na-top__hero-title { font-size: 2.4rem; font-weight: 800; margin: 0 0 0.6rem; letter-spacing: 0.05em; }
.na-top__hero-sub { font-size: 1.05rem; opacity: 0.95; margin: 0 0 1.5rem; line-height: 1.7; }
.na-top__hero-stats { display: flex; justify-content: center; gap: 2rem; margin: 1.5rem 0; }
.na-top__stat { display: flex; flex-direction: column; align-items: center; }
.na-top__stat-num { font-size: 2rem; font-weight: 800; line-height: 1; }
.na-top__stat-label { font-size: 0.78rem; opacity: 0.85; margin-top: 0.3rem; }
.na-top__hero-cta {
	display: inline-block; background: #fff; color: #d44a72;
	padding: 0.9rem 2.2rem; border-radius: 999px; font-weight: 700;
	text-decoration: none; transition: 0.15s;
}
.na-top__hero-cta:hover { background: #fbeaef; color: #d44a72; }

/* 共通セクション */
.na-top__section { margin-bottom: 3rem; }
.na-top__h2 {
	font-size: 1.35rem; font-weight: 700; margin: 0 0 1.2rem;
	padding-left: 0.6rem; border-left: 4px solid #d44a72;
}

/* エリア */
.na-top__area-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.8rem; }
.na-top__area-card {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 1rem; text-align: center; text-decoration: none; color: #222;
	transition: 0.15s;
}
.na-top__area-card:hover { background: #fff; border-color: #d44a72; transform: translateY(-2px); }
.na-top__area-name { font-weight: 700; font-size: 1rem; }
.na-top__area-count { font-size: 0.8rem; color: #888; margin-top: 0.3rem; }

/* 軸 */
.na-top__axes { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.na-top__axis {
	background: #fff; border: 1px solid #e3e6ec; border-radius: 12px; padding: 1rem 1.2rem;
}
.na-top__axis-head { font-weight: 700; margin-bottom: 0.6rem; font-size: 1rem; }
.na-top__axis-icon { margin-right: 0.3rem; }
.na-top__axis-chips { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.na-top__axis-chip {
	display: inline-flex; align-items: center; gap: 0.3rem;
	padding: 0.3rem 0.8rem; font-size: 0.82rem;
	background: #f1f3f6; color: #333; border-radius: 999px;
	border: 1px solid #e3e6ec; text-decoration: none; transition: 0.15s;
}
.na-top__axis-chip:hover { background: #d44a72; color: #fff; border-color: #d44a72; }
.na-top__axis-chip-count { font-size: 0.7rem; opacity: 0.7; }
.na-top__axis-chip:hover .na-top__axis-chip-count { opacity: 1; }

/* 編集部おすすめ */
.na-top__pick-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.na-top__pick-card {
	display: block; background: #fff; border: 1px solid #e3e6ec; border-radius: 12px;
	padding: 1rem; text-decoration: none; color: #222; transition: 0.15s;
}
.na-top__pick-card:hover { border-color: #d44a72; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(212,74,114,0.1); }
.na-top__pick-logo { width: 100%; aspect-ratio: 1.5/1; background: #fafafa; border-radius: 8px; display: flex; align-items: center; justify-content: center; overflow: hidden; margin-bottom: 0.6rem; }
.na-top__pick-logo img { max-width: 80%; max-height: 80%; object-fit: contain; }
.na-top__pick-area { font-size: 0.78rem; color: #666; margin-bottom: 0.2rem; }
.na-top__pick-title { font-weight: 700; font-size: 0.95rem; line-height: 1.4; margin-bottom: 0.3rem; }
.na-top__pick-price { font-size: 0.9rem; color: #d44a72; font-weight: 700; }

/* 新着 */
.na-top__recent-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.8rem; }
.na-top__recent-card {
	display: flex; gap: 0.7rem; background: #fff; border: 1px solid #eee;
	border-radius: 10px; padding: 0.7rem; text-decoration: none; color: #222; transition: 0.15s;
	align-items: center;
}
.na-top__recent-card:hover { border-color: #d44a72; }
.na-top__recent-logo {
	flex: 0 0 56px; width: 56px; height: 56px; background: #fafafa;
	border-radius: 8px; display: flex; align-items: center; justify-content: center;
	overflow: hidden;
}
.na-top__recent-logo img { max-width: 90%; max-height: 90%; object-fit: contain; }
.na-top__recent-logo--empty { font-weight: 700; color: #ccc; font-size: 0.85rem; }
.na-top__recent-body { flex: 1 1 auto; min-width: 0; }
.na-top__recent-area { font-size: 0.72rem; color: #888; }
.na-top__recent-title { font-weight: 700; font-size: 0.88rem; line-height: 1.3; margin: 0.1rem 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.na-top__recent-price { font-size: 0.78rem; color: #d44a72; font-weight: 700; }

/* About */
.na-top__about {
	background: #fafafa; border-radius: 12px; padding: 1.5rem 1.8rem;
	margin-bottom: 2rem;
}
.na-top__about p { line-height: 1.85; margin: 0; color: #444; }

/* スマホ */
@media (max-width: 768px) {
	.na-top__hero-title { font-size: 1.8rem; }
	.na-top__hero-stats { gap: 1.2rem; }
	.na-top__stat-num { font-size: 1.5rem; }
	.na-top__area-grid { grid-template-columns: repeat(2, 1fr); }
	.na-top__axes { grid-template-columns: 1fr; }
	.na-top__pick-grid { grid-template-columns: repeat(2, 1fr); }
	.na-top__recent-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Night Archive — archive-shop.php (店舗一覧)
   ============================================================ */
.na-archive { max-width: 1080px; margin: 0 auto; padding: 1rem; }

/* ヘッダー */
.na-archive__head { margin-bottom: 2rem; }
.na-archive__title {
	font-size: 1.8rem; font-weight: 800; margin: 0 0 0.5rem;
	padding-left: 0.8rem; border-left: 5px solid #d44a72;
}
.na-archive__lead { font-size: 0.95rem; color: #555; margin: 0; line-height: 1.7; }

/* 絞り込みフィルタ */
.na-archive__filter {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 1.2rem 1.4rem; margin-bottom: 1.5rem;
}
.na-archive__axis { margin-bottom: 1rem; }
.na-archive__axis:last-child { margin-bottom: 0; }
.na-archive__axis-head {
	font-weight: 700; font-size: 0.9rem; margin-bottom: 0.5rem; color: #333;
}
.na-archive__axis-icon { margin-right: 0.3rem; }
.na-archive__axis-chips { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.na-archive__chip {
	display: inline-flex; align-items: center; gap: 0.3rem;
	padding: 0.3rem 0.8rem; font-size: 0.8rem;
	background: #fff; color: #444; border-radius: 999px;
	border: 1px solid #ddd; text-decoration: none; transition: 0.12s;
}
.na-archive__chip:hover { background: #fbeaef; border-color: #d44a72; color: #d44a72; }
.na-archive__chip.is-active {
	background: #d44a72; color: #fff; border-color: #d44a72; font-weight: 700;
}
.na-archive__chip-count { font-size: 0.68rem; opacity: 0.7; }
.na-archive__chip.is-active .na-archive__chip-count { opacity: 1; }

.na-archive__filter-clear { margin-top: 1rem; text-align: right; }
.na-archive__clear-btn {
	display: inline-block; padding: 0.4rem 1rem; font-size: 0.82rem;
	background: #fff; color: #d44a72; border: 1px solid #d44a72;
	border-radius: 999px; text-decoration: none; transition: 0.12s;
}
.na-archive__clear-btn:hover { background: #d44a72; color: #fff; }

/* ソート */
.na-archive__sort {
	display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem;
	margin-bottom: 1.5rem;
}
.na-archive__sort-label { font-size: 0.85rem; color: #666; font-weight: 700; }
.na-archive__sort-chip {
	display: inline-block; padding: 0.35rem 0.9rem; font-size: 0.82rem;
	background: #f1f3f6; color: #444; border-radius: 999px;
	text-decoration: none; transition: 0.12s; border: 1px solid transparent;
}
.na-archive__sort-chip:hover { background: #e8ecf1; }
.na-archive__sort-chip.is-active {
	background: #333; color: #fff; font-weight: 700;
}

/* カードグリッド */
.na-archive__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem;
	margin-bottom: 2.5rem;
}
.na-archive__card {
	position: relative; display: flex; flex-direction: column;
	background: #fff; border: 1px solid #e3e6ec; border-radius: 12px;
	overflow: hidden; text-decoration: none; color: #222; transition: 0.15s;
}
.na-archive__card:hover {
	border-color: #d44a72; transform: translateY(-3px);
	box-shadow: 0 6px 18px rgba(212,74,114,0.12);
}
.na-archive__badge {
	position: absolute; top: 0.6rem; right: 0.6rem; z-index: 2;
	background: #ffba00; color: #fff; font-size: 0.72rem; font-weight: 700;
	padding: 0.2rem 0.55rem; border-radius: 999px;
}
.na-archive__card-logo {
	width: 100%; aspect-ratio: 1.6/1; background: #fafafa;
	display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.na-archive__card-logo img { max-width: 80%; max-height: 80%; object-fit: contain; }
.na-archive__card-logo-empty { font-weight: 700; color: #ccc; font-size: 1.1rem; }
.na-archive__card-body { padding: 0.9rem 1rem 1.1rem; flex: 1 1 auto; display: flex; flex-direction: column; }
.na-archive__card-area { font-size: 0.78rem; color: #666; margin-bottom: 0.25rem; }
.na-archive__card-title { font-weight: 700; font-size: 1rem; line-height: 1.4; margin-bottom: 0.6rem; min-height: 2.8em; }
.na-archive__card-meta { margin-bottom: 0.7rem; }
.na-archive__card-price { font-size: 0.95rem; font-weight: 700; color: #d44a72; line-height: 1.4; }
.na-archive__card-price-num { font-size: 1.1rem; }
.na-archive__card-price-type { font-size: 0.72rem; font-weight: 500; color: #888; }
.na-archive__card-time { font-size: 0.82rem; color: #555; margin-top: 0.2rem; }
.na-archive__card-tags { display: flex; flex-wrap: wrap; gap: 0.3rem; margin-top: auto; }
.na-archive__card-tag {
	display: inline-block; padding: 0.15rem 0.55rem; font-size: 0.72rem;
	background: #f1f3f6; color: #555; border-radius: 999px;
}

/* ページネーション */
.na-archive__pagination { display: flex; justify-content: center; margin: 2rem 0; }
.na-archive__pagination ul.page-numbers {
	display: flex; flex-wrap: wrap; gap: 0.3rem; list-style: none;
	margin: 0; padding: 0;
}
.na-archive__pagination .page-numbers {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 2.2rem; padding: 0.4rem 0.7rem; font-size: 0.88rem;
	background: #fff; color: #444; border: 1px solid #ddd; border-radius: 6px;
	text-decoration: none; transition: 0.12s;
}
.na-archive__pagination a.page-numbers:hover {
	background: #fbeaef; border-color: #d44a72; color: #d44a72;
}
.na-archive__pagination .page-numbers.current {
	background: #d44a72; color: #fff; border-color: #d44a72; font-weight: 700;
}

/* 空表示 */
.na-archive__empty {
	background: #fafafa; border: 1px solid #eee; border-radius: 12px;
	padding: 3rem 1.5rem; text-align: center; color: #666;
}
.na-archive__empty p { margin: 0 0 1rem; }

/* スマホ */
@media (max-width: 768px) {
	.na-archive__title { font-size: 1.4rem; }
	.na-archive__grid { grid-template-columns: repeat(2, 1fr); gap: 0.8rem; }
	.na-archive__card-body { padding: 0.7rem 0.8rem 0.9rem; }
	.na-archive__card-title { font-size: 0.9rem; min-height: 2.5em; }
	.na-archive__card-price-num { font-size: 1rem; }
	.na-archive__filter { padding: 1rem; }
}
@media (max-width: 480px) {
	.na-archive__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Night Archive — 訴求枠（PCMAXネイティブ / グリッド型バナー集）
   ============================================================ */

/* 共通: PRラベル */
.na-promo__pr {
	display: inline-block;
	font-size: 0.65rem; font-weight: 700; line-height: 1;
	padding: 0.18rem 0.45rem; border-radius: 3px;
	background: #888; color: #fff; letter-spacing: 0.05em;
	vertical-align: middle;
}

/* ====== ネイティブ訴求枠（記事内・PCMAX等） ====== */
.na-promo--native {
	position: relative;
	margin: 2.5rem 0;
	border: 1px solid #f1d4d4;
	background: linear-gradient(135deg, #fff7f9 0%, #ffeef3 100%);
	border-radius: 14px; padding: 1.2rem 1.4rem 1.4rem;
	box-shadow: 0 2px 8px rgba(212,74,114,0.06);
}
.na-promo--native > .na-promo__pr {
	position: absolute; top: 0.7rem; right: 0.9rem;
	background: #d44a72;
}
.na-promo__native-link {
	display: grid; grid-template-columns: 200px 1fr; gap: 1.2rem;
	align-items: center; text-decoration: none; color: #222;
}
.na-promo__native-image {
	width: 200px; aspect-ratio: 3/1;
	background: #fff; border-radius: 10px; overflow: hidden;
	display: flex; align-items: center; justify-content: center;
	border: 1px solid #f1d4d4;
}
.na-promo__native-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.na-promo__native-body { display: flex; flex-direction: column; gap: 0.4rem; min-width: 0; }
.na-promo__native-headline {
	font-size: 1.1rem; font-weight: 800; color: #b53d61; line-height: 1.4;
}
.na-promo__native-text { font-size: 0.92rem; color: #444; line-height: 1.6; }
.na-promo__native-cta {
	display: inline-block; margin-top: 0.3rem;
	color: #d44a72; font-weight: 700; font-size: 0.92rem;
}
.na-promo__native-link:hover .na-promo__native-cta { text-decoration: underline; }

/* ====== グリッド型バナー集 ====== */
.na-promo--grid {
	margin: 2.5rem 0;
	background: #fafafa;
	border: 1px solid #eee;
	border-radius: 14px;
	padding: 1.2rem 1.4rem 1.5rem;
}
.na-promo__grid-head {
	display: flex; align-items: center; gap: 0.6rem;
	margin-bottom: 1rem;
}
.na-promo__grid-title {
	font-weight: 800; font-size: 1.05rem; color: #333;
}
.na-promo__grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.9rem;
}
.na-promo__grid-card {
	display: flex; flex-direction: column;
	background: #fff; border: 1px solid #e3e6ec; border-radius: 10px;
	overflow: hidden; text-decoration: none; color: #222; transition: 0.15s;
}
.na-promo__grid-card:hover {
	border-color: #d44a72; transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(212,74,114,0.12);
}
.na-promo__grid-image {
	width: 100%; aspect-ratio: 3/1; overflow: hidden;
	background: #fafafa;
}
.na-promo__grid-image img { width: 100%; height: 100%; object-fit: cover; display: block; }
.na-promo__grid-text { padding: 0.7rem 0.9rem 0.9rem; }
.na-promo__grid-name {
	font-size: 0.82rem; color: #888; font-weight: 700; margin-bottom: 0.2rem;
}
.na-promo__grid-headline {
	font-size: 0.92rem; color: #222; font-weight: 700; line-height: 1.4;
}

/* ====== スマホ ====== */
@media (max-width: 768px) {
	.na-promo--native { padding: 1rem 1rem 1.2rem; }
	.na-promo__native-link {
		grid-template-columns: 1fr; gap: 0.8rem;
	}
	.na-promo__native-image { width: 100%; aspect-ratio: 3/1; }
	.na-promo__native-headline { font-size: 1rem; }
	.na-promo__grid { grid-template-columns: 1fr; }
}

/* =========================================================
   タクソノミー軸アーカイブ (taxonomy.php) — STEP 15-a
   ========================================================= */
.na-tax__breadcrumb {
	font-size: 0.82rem; color: #888; margin-bottom: 0.8rem;
	display: flex; flex-wrap: wrap; gap: 0.3rem; align-items: center;
}
.na-tax__breadcrumb a { color: #d44a72; text-decoration: none; }
.na-tax__breadcrumb a:hover { text-decoration: underline; }
.na-tax__breadcrumb-sep { color: #ccc; }
.na-tax__breadcrumb-current { color: #555; }

.na-tax__h1-icon { margin-right: 0.4rem; }

.na-tax__intro {
	background: #fafafa; border: 1px solid #eee; border-left: 4px solid #d44a72;
	border-radius: 12px; padding: 1.1rem 1.3rem; margin: 1rem 0 1.6rem;
	line-height: 1.9; color: #333; font-size: 0.96rem;
}
.na-tax__intro p { margin: 0 0 0.8rem; }
.na-tax__intro p:last-child { margin-bottom: 0; }

.na-tax__cross {
	margin-top: 2.4rem; padding-top: 1.6rem; border-top: 1px dashed #e3e6ec;
}
.na-tax__cross-title {
	font-size: 1.1rem; font-weight: 700; color: #222;
	padding-left: 0.6rem; border-left: 4px solid #d44a72; margin-bottom: 1rem;
}
.na-tax__cross-axis { margin-bottom: 1rem; }
.na-tax__cross-label {
	font-size: 0.86rem; font-weight: 700; color: #555; margin-bottom: 0.45rem;
}
.na-tax__cross-icon { margin-right: 0.3rem; }
.na-tax__cross-chips { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.na-tax__cross-chip {
	display: inline-flex; align-items: center; gap: 0.3rem;
	background: #f1f3f6; color: #333; border: 1px solid #e3e6ec;
	border-radius: 999px; padding: 0.32rem 0.8rem; font-size: 0.84rem;
	text-decoration: none; transition: background .15s;
}
.na-tax__cross-chip:hover { background: #fbeaef; color: #d44a72; }
.na-tax__cross-count {
	background: #fff; color: #999; border-radius: 999px;
	padding: 0 0.4rem; font-size: 0.74rem; font-weight: 700;
}
.na-tax__cross-all { margin-top: 1.2rem; }

/* =========================================================
   single-shop SEO補強 (STEP 16) — 軸termリンク化＋関連店舗
   ========================================================= */
.na-shop__highlight-value a { color: #d44a72; text-decoration: none; }
.na-shop__highlight-value a:hover { text-decoration: underline; }
a.na-shop__chip { text-decoration: none; transition: background .15s; }
a.na-shop__chip:hover { background: #fbeaef; color: #d44a72; }

.na-shop__related { margin-top: 2.5rem; }
.na-shop__related-more { margin-top: 1.2rem; text-align: center; }
.na-shop__related-link {
	display: inline-block; background: #d44a72; color: #fff;
	border-radius: 999px; padding: 0.55rem 1.4rem; font-size: 0.9rem;
	font-weight: 700; text-decoration: none; transition: background .15s;
}
.na-shop__related-link:hover { background: #b53d61; color: #fff; }
