/* ===== ヘッダー ===== */
.site-header {
	background: var(--color-bg);
	border-bottom: 3px solid var(--color-primary);
	position: sticky;
	top: 0;
	z-index: 100;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .06);
}

.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 64px;
}

/* ロゴ */
.site-logo {
	display: flex;
	align-items: center;
}

.site-logo__img {
	height: 44px;
	width: auto;
	display: block;
}

@media (max-width: 768px) {
	.site-logo__img {
		height: 38px;
	}
}

/* ハンバーガー（CSSのみ checkbox toggle） */
.site-header__toggle-input {
	display: none;
}

.site-header__toggle {
	display: none;
	flex-direction: column;
	align-items: center;
	cursor: pointer;
	padding: 8px;
	gap: 2px;
}

.site-header__toggle-icon {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.site-header__toggle-icon::before,
.site-header__toggle-icon,
.site-header__toggle-icon::after {
	content: '';
	display: block;
	width: 24px;
	height: 2px;
	background: var(--color-text);
	border-radius: 2px;
	transition: transform var(--transition), opacity var(--transition);
}

/* ナビ */
.site-header__nav {
	width: auto;
}

.site-header__menu {
	display: flex;
	list-style: none;
	gap: 4px;
	margin: 0;
	padding: 0;
}

.site-header__menu a {
	display: block;
	padding: 8px 14px;
	border-radius: var(--radius);
	font-size: 14px;
	font-weight: 600;
	color: var(--color-text);
	transition: background var(--transition), color var(--transition);
}

.site-header__menu a:hover,
.site-header__menu a.is-current {
	background: var(--color-primary);
	color: #fff;
}

.site-header__line-btn {
	background: #06C755 !important;
	color: #fff !important;
	border-radius: var(--radius) !important;
}

.site-header__line-btn:hover {
	opacity: .88;
	background: #06C755 !important;
}

@media (max-width: 768px) {
	.site-header__toggle {
		display: flex;
	}

	.site-header__nav {
		width: 100%;
		max-height: 0;
		overflow: hidden;
		transition: max-height 0.3s ease;
		order: 3;
	}

	.site-header__toggle-input:checked ~ .site-header__nav {
		max-height: 500px;
	}

	.site-header__inner {
		flex-wrap: wrap;
	}

	.site-header__menu {
		flex-direction: column;
		gap: 0;
		padding: 8px 0 16px;
	}

	.site-header__menu li {
		border-bottom: 1px solid var(--color-border);
	}

	.site-header__menu a {
		padding: 14px 4px;
		border-radius: 0;
	}

	.site-header__menu a:hover,
	.site-header__menu a.is-current {
		background: var(--color-primary-light);
		color: var(--color-primary);
	}

	.site-header__line-btn {
		background: #06C755 !important;
		color: #fff !important;
		margin: 8px 0 0;
		border-radius: var(--radius) !important;
		text-align: center;
	}
}

/* ===== フッター ===== */
.site-footer {
	background: var(--color-primary-dark);
	color: rgba(255, 255, 255, .7);
	padding: 48px 0 24px;
	margin-top: 48px;
}

body.mode-voucher .site-footer {
	background: var(--color-voucher-dark);
}

body.mode-campaign .site-footer {
	background: var(--color-campaign-dark);
}

.footer-inner {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 40px;
	margin-bottom: 40px;
}

.footer-brand__logo {
	font-size: 20px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 10px;
}

.footer-brand__logo-img {
	display: block;
	width: auto;
	height: 56px;
	background: #fff;
	border-radius: var(--radius);
	padding: 10px 14px;
	margin-bottom: 14px;
}

.footer-brand__desc {
	font-size: 13px;
	line-height: 1.7;
}

.footer-nav__title {
	font-size: 13px;
	font-weight: 700;
	color: #fff;
	margin-bottom: 12px;
	letter-spacing: .05em;
}

.footer-nav ul {
	list-style: none;
}

.footer-nav li {
	margin-bottom: 8px;
}

.footer-nav a {
	font-size: 13px;
	transition: color var(--transition);
}

.footer-nav a:hover {
	color: rgba(255, 255, 255, 1);
}

.footer-bottom-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px 24px;
	padding: 16px 0;
	border-top: 1px solid rgba(255, 255, 255, .12);
	margin-bottom: 8px;
}

.footer-bottom-nav a {
	font-size: 12px;
	color: rgba(255, 255, 255, .6);
}

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, .12);
	padding-top: 20px;
	text-align: center;
	font-size: 12px;
}

.footer-bottom p {
	margin: 4px 0;
}

@media (max-width: 768px) {
	.footer-inner {
		grid-template-columns: 1fr;
		gap: 24px;
	}
}

/* ===== ヒーロー ===== */
.hero {
	position: relative;
	background-color: var(--color-primary);
	background-size: cover;
	background-position: center;
	color: #fff;
	padding: 48px 0 56px;
	text-align: center;
}

.hero--voucher {
	background-color: var(--color-voucher);
}

.hero--campaign {
	background-color: var(--color-campaign);
}

.hero__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .4);
}

/* ===== 画像ヒーロー（完成バナー画像＝コピー・イラスト／直下にHTMLボタン・検索窓） ===== */
/* .hero 基底＋PC用メディアクエリの padding を確実に打ち消すため specificity を上げる。 */
.hero.hero--image {
	background: none;
	padding: 0;
	min-height: 0;
	display: block;
}

/* バナー画像本体。16:9 で原則フル表示（クロップなし）。超ワイドのみ上下を軽くクロップ。 */
.hero__banner {
	width: 100%;
	aspect-ratio: 16 / 9;
	max-height: 820px;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	display: block;
}

/* 画像直下のアクション帯（ボタン・検索窓）。重なりを避け、確実に操作できる。 */
.hero__actions {
	background: var(--color-bg);
	padding: 24px 0 32px;
	text-align: center;
}

.hero__actions .hero__btns {
	margin: 0;
}

.hero__actions .hero__search {
	margin: 20px 0 0;
}

/* 画面読み上げ・SEO用の非表示見出し（WP標準の screen-reader-text 相当） */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	width: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute;
}

@media (max-width: 767px) {
	/* スマホは縦長になりすぎないよう高さを抑え、中央コピーを見せる。 */
	.hero__banner {
		aspect-ratio: auto;
		height: 56vw;
		min-height: 220px;
		max-height: 360px;
	}
}

/* 写真ヒーロー（明るい福井駅前写真＋濃色テキスト・モックアップ準拠） */
.hero--photo {
	color: var(--color-text);
	padding: 88px 0 96px;
	overflow: hidden;
}

.hero--photo .hero__overlay {
	background:
		radial-gradient(120% 90% at 50% 0%, rgba(255, 255, 255, .82) 0%, rgba(255, 255, 255, .5) 40%, rgba(255, 255, 255, .12) 75%);
}

.hero--photo .hero__inner {
	max-width: 820px;
}

.hero--photo .hero__lead {
	color: var(--color-text);
	font-size: var(--font-size-lg);
	margin: 0 0 4px;
}

.hero--photo .hero__search .shop-search__label {
	color: var(--color-text);
}

.hero__accent {
	color: var(--color-accent);
}

/* 2行見出し（モックアップ準拠：1行目は小さめ、2行目の「お得」を特大マゼンタ） */
.hero__title--photo {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
	margin: 0 0 14px;
	line-height: 1.15;
}

.hero__title-sub {
	font-size: clamp(20px, 3.4vw, 30px);
	font-weight: 700;
	color: var(--color-text);
}

.hero__title-main {
	font-size: clamp(34px, 7vw, 60px);
	font-weight: 700;
	letter-spacing: .01em;
}

.hero__title--photo .hero__accent {
	font-size: 1.35em;
}

/* 装飾アイコン（白い線画・PCのみ表示） */
.hero__decor {
	display: none;
}

@media (min-width: 768px) {
	.hero__decor {
		display: block;
		position: absolute;
		inset: 0;
		z-index: 1;
		pointer-events: none;
	}

	.hero__decor-icon {
		position: absolute;
		opacity: .85;
		filter: drop-shadow(0 1px 2px rgba(0, 0, 0, .15));
	}

	.hero__decor-icon--fork   { width: 30px; height: 30px; top: 24%; left: 22%; transform: rotate(-12deg); }
	.hero__decor-icon--cup    { width: 34px; height: 34px; top: 50%; left: 16%; transform: rotate(8deg); }
	.hero__decor-icon--ticket { width: 40px; height: 40px; top: 26%; right: 20%; transform: rotate(14deg); }
	.hero__decor-icon--bag    { width: 32px; height: 32px; top: 50%; right: 17%; transform: rotate(-8deg); }
	.hero__decor-icon--star1  { width: 22px; height: 22px; top: 16%; right: 30%; }
	.hero__decor-icon--star2  { width: 16px; height: 16px; top: 60%; right: 28%; }
}

.hero__inner {
	position: relative;
	z-index: 1;
	max-width: 480px;
	margin: 0 auto;
}

.hero__title {
	font-size: var(--font-size-xl);
	margin: 0 0 12px;
	white-space: pre-line;
	font-weight: 700;
}

.hero--photo .hero__title {
	font-size: clamp(28px, 6vw, 48px);
	line-height: 1.25;
}

.hero__lead {
	font-size: var(--font-size-base);
	margin: 0 0 8px;
}

/* ヒーローボタン（プレビュー用） */
.hero__btns {
	display: flex;
	gap: 14px;
	justify-content: center;
	flex-wrap: wrap;
	margin: 24px 0 8px;
}

.hero-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 36px;
	border-radius: var(--radius-pill);
	font-size: var(--font-size-base);
	font-weight: 700;
	transition: transform var(--transition), box-shadow var(--transition), opacity var(--transition);
	box-shadow: var(--shadow);
}

.hero-btn:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-hover);
	text-decoration: none;
}

.hero-btn--primary {
	background: var(--color-accent);
	color: #fff;
}

.hero-btn--outline {
	background: #fff;
	color: var(--color-accent);
	border: 2px solid var(--color-accent);
}

/* モード別アクセント色（通常＝ピンク／お買い物券＝暖色オレンジ／LINEクーポン＝LINEグリーン） */
.hero--voucher .hero__accent {
	color: var(--color-voucher);
}

.hero--voucher .hero-btn--primary {
	background: var(--color-voucher);
}

.hero--voucher .hero-btn--outline {
	color: var(--color-voucher);
	border-color: var(--color-voucher);
}

.hero--campaign .hero__accent {
	color: var(--color-campaign);
}

.hero--campaign .hero-btn--primary {
	background: var(--color-campaign);
}

.hero--campaign .hero-btn--outline {
	color: var(--color-campaign);
	border-color: var(--color-campaign);
}

/* リボン見出し（サブコピーをモード色の帯で表示・モックアップ準拠） */
.hero__eyebrow {
	display: inline-block;
	background: var(--color-accent);
	color: #fff;
	font-size: 15px;
	font-weight: 700;
	padding: 7px 22px;
	border-radius: var(--radius-pill);
	margin: 0 0 14px;
	letter-spacing: .03em;
}

.hero--voucher .hero__eyebrow {
	background: var(--color-voucher);
}

.hero--campaign .hero__eyebrow {
	background: var(--color-campaign);
}

/* 利用期間 */
.hero__period {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 14px 0 0;
	font-size: 15px;
	font-weight: 600;
	color: var(--color-text);
}

.hero__period-label {
	background: var(--color-text);
	color: #fff;
	font-size: 13px;
	font-weight: 700;
	padding: 3px 12px;
	border-radius: var(--radius-pill);
}

/* 金額・割引バッジ */
.hero__badge {
	display: inline-block;
	margin: 14px 0 0;
	background: #fff;
	border: 2px dashed var(--color-voucher);
	color: var(--color-voucher);
	font-size: var(--font-size-lg);
	font-weight: 700;
	padding: 10px 24px;
	border-radius: var(--radius);
}

.hero--campaign .hero__badge {
	border-color: var(--color-campaign);
	color: var(--color-campaign);
}

.hero-btn__icon {
	font-size: 1.1em;
	line-height: 1;
}

.hero-btn__chevron {
	font-size: 1.2em;
	line-height: 1;
	margin-left: 4px;
}

.hero__amount {
	display: inline-block;
	background: rgba(255, 255, 255, .2);
	border-radius: var(--radius-pill);
	padding: 8px 20px;
	font-size: var(--font-size-base);
	font-weight: 600;
	margin: 8px 0 24px;
}

.hero__search {
	margin: 28px 0 0;
}

/* ヒーロー内の検索窓は負マージンを使わない（ボタンと重ならないように） */
.hero__search .shop-search {
	margin: 0 auto;
}

.hero__search .shop-search__label {
	color: #fff;
}

.hero--photo .hero__search .shop-search__label {
	color: var(--color-text);
}

.hero__search .shop-search__input {
	font-size: var(--font-size-lg);
}

@media (min-width: 768px) {
	.hero {
		padding: 72px 0;
	}

	.hero__inner {
		max-width: 600px;
	}
}

/* ===== 店舗名検索 ===== */
.shop-search {
	margin: -28px auto 0;
	max-width: 600px;
	position: relative;
	z-index: 2;
}

.shop-search__label {
	display: block;
	text-align: center;
	font-weight: 600;
	font-size: 14px;
	letter-spacing: .08em;
	margin-bottom: 10px;
	color: var(--color-text);
}

.shop-search__row {
	display: flex;
	align-items: center;
	gap: 10px;
	background: #fff;
	border-radius: var(--radius-pill);
	border: 1px solid #ececec;
	padding: 7px 7px 7px 22px;
	box-shadow: 0 10px 30px rgba(0, 0, 0, .10), 0 2px 6px rgba(0, 0, 0, .05);
	transition: box-shadow var(--transition), border-color var(--transition);
}

.shop-search__row:focus-within {
	border-color: var(--color-primary);
	box-shadow: 0 10px 30px rgba(74, 124, 89, .18), 0 0 0 3px var(--color-primary-light);
}

.shop-search__icon {
	flex: 0 0 auto;
	color: var(--color-text-muted);
}

.shop-search__input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: var(--font-size-base);
	outline: none;
	min-width: 0;
	color: var(--color-text);
}

.shop-search__input::placeholder {
	color: #b0b0b0;
}

/* 検索の虫眼鏡を消す（type=search のネイティブ装飾） */
.shop-search__input::-webkit-search-decoration,
.shop-search__input::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

.shop-search__submit {
	background: var(--color-primary);
	color: #fff;
	border: none;
	border-radius: var(--radius-pill);
	padding: 13px 32px;
	font-size: var(--font-size-base);
	font-weight: 600;
	letter-spacing: .05em;
	cursor: pointer;
	white-space: nowrap;
	transition: background var(--transition), transform var(--transition);
}

.shop-search__submit:hover {
	background: var(--color-primary-dark);
	transform: translateY(-1px);
}

.section--archive .shop-search {
	margin: 0 0 8px;
	max-width: none;
}

.shop-search__result-info {
	margin: 0 0 24px;
	color: var(--color-text-muted);
}

.shop-search__result-info a {
	margin-left: 8px;
}

/* ===== セクション共通 ===== */
.section {
	padding: 64px 0;
}

.section--gray {
	background: var(--color-primary-light);
}

.section__title {
	font-size: var(--font-size-lg);
	margin: 0 0 24px;
	font-weight: 700;
}

.section__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 16px;
}

.section__header .section__title {
	margin-bottom: 0;
}

.section__header-link {
	font-size: 14px;
	color: var(--color-primary);
	font-weight: 600;
}

.section__more {
	text-align: center;
	margin-top: 24px;
}

.section__more-link {
	display: inline-block;
	background: var(--color-primary);
	color: #fff;
	padding: 14px 36px;
	border-radius: var(--radius-pill);
	font-weight: 600;
	transition: background var(--transition);
}

.section__more-link:hover {
	background: var(--color-primary-dark);
}

/* セクションヘッダー（ピルラベル付き） */
.section-header {
	text-align: center;
	margin-bottom: 40px;
}

.section-header__label {
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: .15em;
	color: var(--color-primary);
	background: rgba(74, 124, 89, .1);
	padding: 4px 14px;
	border-radius: var(--radius-pill);
	margin-bottom: 10px;
}

.section-header__title {
	font-size: clamp(22px, 4vw, 32px);
	font-weight: 700;
	line-height: 1.3;
}

.section-header__desc {
	margin-top: 10px;
	color: var(--color-text-muted);
	font-size: 14px;
}

/* ===== エリアカード ===== */
.area-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 16px;
}

.area-card {
	background: var(--color-bg);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 28px 20px;
	text-align: center;
	transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
	border: 2px solid transparent;
	color: var(--color-text);
}

.area-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-hover);
	border-color: var(--color-primary);
}

.area-card__name {
	font-size: 15px;
	font-weight: 700;
	margin-bottom: 4px;
}

.area-card__count {
	font-size: 12px;
	color: var(--color-text-muted);
}

@media (max-width: 480px) {
	.area-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ===== 業種バッジ ===== */
.cat-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	justify-content: center;
}

.cat-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 10px 20px;
	border-radius: var(--radius-pill);
	font-size: 14px;
	font-weight: 600;
	border: 2px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-text);
	transition: all var(--transition);
}

.cat-badge:hover,
.cat-badge.is-active {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

/* ===== 券種カード ===== */
.coupon-type-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

@media (min-width: 600px) {
	.coupon-type-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.coupon-type-card {
	display: flex;
	align-items: center;
	gap: 16px;
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	border-radius: var(--radius);
	padding: 24px;
	font-weight: 600;
	font-size: var(--font-size-base);
	color: var(--color-text);
	transition: border-color var(--transition), box-shadow var(--transition);
	box-shadow: var(--shadow);
}

.coupon-type-card:hover {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-hover);
}

.coupon-type-card__label {
	font-weight: 700;
}

/* ===== フィルターバー ===== */
.filter-bar {
	background: var(--color-bg);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	padding: 20px 24px;
	margin-bottom: 32px;
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
}

.filter-bar__label {
	font-size: 13px;
	font-weight: 700;
	color: var(--color-text-muted);
	white-space: nowrap;
}

.filter-group {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	flex: 1;
}

.filter-btn {
	padding: 6px 16px;
	border-radius: var(--radius-pill);
	font-size: 13px;
	font-weight: 600;
	border: 1.5px solid var(--color-border);
	background: var(--color-bg);
	color: var(--color-text);
	cursor: pointer;
	transition: all var(--transition);
	white-space: nowrap;
	text-decoration: none;
	display: inline-block;
}

.filter-btn:hover,
.filter-btn.is-active {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

.filter-divider {
	width: 1px;
	height: 32px;
	background: var(--color-border);
}

@media (max-width: 768px) {
	.filter-bar {
		flex-direction: column;
		align-items: flex-start;
	}

	.filter-divider {
		width: 100%;
		height: 1px;
	}
}

/* ===== ページヘッダー（タクソノミーアーカイブ） ===== */
.page-header {
	background: linear-gradient(135deg, var(--color-primary-light) 0%, rgba(74, 124, 89, .08) 100%);
	padding: 40px 0 32px;
	border-bottom: 3px solid var(--color-primary);
}

.page-header__title {
	font-size: clamp(22px, 4vw, 32px);
	font-weight: 700;
	color: var(--color-text);
}

.page-header__desc {
	color: var(--color-text-muted);
	font-size: 14px;
	margin-top: 6px;
}

.breadcrumb {
	padding: 12px 0;
	font-size: 13px;
	color: var(--color-text-muted);
	display: flex;
	gap: 6px;
	align-items: center;
	flex-wrap: wrap;
}

.breadcrumb a {
	color: var(--color-primary);
}

.breadcrumb a:hover {
	text-decoration: underline;
}

/* ===== 店舗グリッド／カード ===== */
.shop-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 24px;
}

.shop-card {
	background: var(--color-bg);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
	transition: transform var(--transition), box-shadow var(--transition);
	display: flex;
	flex-direction: column;
	position: relative;
}

.shop-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--shadow-hover);
}

.shop-card__link {
	display: flex;
	flex-direction: column;
	flex: 1;
	color: var(--color-text);
}

.shop-card__thumb {
	position: relative;
	width: 100%;
	height: 180px;
	background: linear-gradient(135deg, var(--color-primary-light), rgba(74, 124, 89, .15));
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 48px;
}

.shop-card__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.shop-card__badge {
	position: absolute;
	top: 8px;
	left: 8px;
	background: var(--color-badge);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	padding: 3px 10px;
	border-radius: var(--radius-pill);
	z-index: 2;
}

.shop-card__body {
	padding: 18px;
	flex: 1;
	display: flex;
	flex-direction: column;
}

/* タグ行 */
.shop-card__tags {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	margin-bottom: 10px;
}

.tag {
	font-size: 11px;
	font-weight: 600;
	padding: 3px 10px;
	border-radius: var(--radius-pill);
}

.tag--area {
	background: rgba(74, 124, 89, .12);
	color: var(--color-primary-dark);
}

.tag--industry {
	background: var(--color-primary-light);
	color: var(--color-text-muted);
}

.tag--service {
	background: rgba(6, 199, 85, .12);
	color: #059952;
	font-weight: 700;
}

.shop-card__title {
	font-size: 17px;
	font-weight: 700;
	margin-bottom: 8px;
	line-height: 1.4;
	pointer-events: none;
}

.shop-card__services {
	display: flex;
	gap: 4px;
	flex-wrap: wrap;
	margin-bottom: 8px;
}

.shop-card__footer {
	margin-top: auto;
	padding-top: 14px;
	border-top: 1px solid var(--color-border);
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 12px;
	color: var(--color-text-muted);
}

.shop-card__tel {
	font-size: 13px;
	font-weight: 600;
	color: var(--color-primary);
}

/* ===== 参加店舗一覧（PC6列×2段・モバイル横長カード） ===== */
.shop-grid--scroll {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: 220px;
	overflow-x: auto;
	gap: 16px;
	padding-bottom: 8px;
	align-items: start;
}

.shop-grid--dense {
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
}

.shop-grid--dense .shop-card__link {
	flex-direction: row;
}

.shop-grid--dense .shop-card__thumb {
	width: 90px;
	height: auto;
	flex: 0 0 90px;
	min-height: 80px;
}

.shop-grid--dense .shop-card__body {
	flex: 1;
	padding: 10px 12px;
	min-width: 0;
}

.shop-grid--dense .shop-card__title {
	font-size: 13px;
	margin: 0 0 4px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.shop-grid--dense .shop-card__tags {
	margin-bottom: 4px;
}

.shop-grid--dense .tag {
	font-size: 10px;
	padding: 2px 7px;
}

.shop-grid--dense .shop-card__badge {
	font-size: 10px;
	padding: 2px 7px;
}

.shop-grid--dense .shop-card__footer {
	margin-top: 4px;
	padding-top: 6px;
}

@media (min-width: 600px) {
	.shop-grid--dense {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (min-width: 900px) {
	.shop-grid--dense {
		grid-template-columns: repeat(6, 1fr);
	}

	.shop-grid--dense .shop-card__link {
		flex-direction: column;
	}

	.shop-grid--dense .shop-card__thumb {
		width: 100%;
		flex: none;
		height: 120px;
	}
}

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

/* ===== お知らせ ===== */
.notice-list {
	list-style: none;
	margin: 0;
	padding: 0;
	border-top: 1px solid var(--color-border);
}

.notice-list__item {
	border-bottom: 1px solid var(--color-border);
}

.notice-list__item a {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 14px 4px;
	color: var(--color-text);
	transition: color var(--transition);
}

.notice-list__item a:hover {
	color: var(--color-primary);
}

.notice-list__date {
	color: var(--color-text-muted);
	font-size: 14px;
	flex: 0 0 56px;
}

.notice-list__title {
	flex: 1;
}

.notice-list__arrow {
	color: var(--color-text-muted);
}

/* ===== ページネーション ===== */
.pagination {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-top: 48px;
	flex-wrap: wrap;
}

.pagination a,
.pagination span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: var(--radius);
	font-size: 14px;
	font-weight: 600;
	border: 1.5px solid var(--color-border);
	transition: all var(--transition);
}

.pagination a:hover,
.pagination .current {
	background: var(--color-primary);
	border-color: var(--color-primary);
	color: #fff;
}

/* ===== no-results ===== */
.no-results {
	text-align: center;
	padding: 60px 20px;
	color: var(--color-text-muted);
}

.no-results p {
	font-size: 16px;
	margin-bottom: 16px;
}

/* ===== 店舗詳細 ===== */
.shop-layout {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 40px;
	align-items: start;
}

.shop-hero-img {
	width: 100%;
	height: 320px;
	object-fit: cover;
	border-radius: var(--radius);
	margin-bottom: 28px;
}

.shop-hero-placeholder {
	width: 100%;
	height: 320px;
	background: linear-gradient(135deg, var(--color-primary-light), rgba(74, 124, 89, .15));
	border-radius: var(--radius);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 88px;
	margin-bottom: 28px;
}

.shop-detail__tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin-bottom: 12px;
}

.shop-detail__title {
	font-size: 28px;
	font-weight: 700;
	margin-bottom: 16px;
}

.shop-intro {
	font-size: 15px;
	line-height: 1.9;
	color: var(--color-text);
	margin: 20px 0 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--color-border);
}

/* サイドバーカード */
.info-card {
	background: var(--color-bg);
	border-radius: var(--radius);
	box-shadow: var(--shadow);
	overflow: hidden;
	margin-bottom: 20px;
}

.info-card__header {
	background: var(--color-primary);
	color: #fff;
	padding: 12px 18px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .05em;
}

.info-card__body {
	padding: 16px 18px;
}

.info-row {
	display: flex;
	gap: 10px;
	padding: 9px 0;
	border-bottom: 1px solid var(--color-border);
	font-size: 14px;
	align-items: flex-start;
}

.info-row:last-child {
	border-bottom: none;
}

.info-row__label {
	color: var(--color-text-muted);
	font-size: 12px;
	font-weight: 600;
	white-space: nowrap;
	min-width: 64px;
	padding-top: 2px;
}

.info-row__value {
	flex: 1;
	line-height: 1.5;
}

.info-row__value a {
	color: var(--color-primary);
}

.info-row__value a:hover {
	text-decoration: underline;
}

/* SNSリンク */
.sns-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 16px;
}

.sns-link {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 9px 18px;
	border-radius: var(--radius-pill);
	font-size: 13px;
	font-weight: 600;
	transition: opacity var(--transition), transform var(--transition);
	color: #fff;
}

.sns-link:hover {
	opacity: .85;
	transform: translateY(-2px);
}

.sns-link--instagram {
	background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
}

.sns-link--twitter {
	background: #000000;
}

.sns-link--facebook {
	background: #1877F2;
}

.sns-link--line {
	background: #06C755;
}

.sns-link--tiktok {
	background: #010101;
}

.sns-link--web {
	background: var(--color-primary);
}

/* 地図ボタン */
.map-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	width: 100%;
	padding: 11px;
	border-radius: var(--radius);
	background: var(--color-primary-light);
	font-size: 13px;
	font-weight: 600;
	color: var(--color-text);
	transition: background var(--transition);
}

.map-btn:hover {
	background: var(--color-border);
}

/* ギャラリー */
.shop-gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: 12px;
	margin-top: 16px;
}

.shop-gallery img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
	border-radius: var(--radius);
}

@media (max-width: 768px) {
	.shop-layout {
		grid-template-columns: 1fr;
	}

	.shop-sidebar {
		order: -1;
	}
}

/* ===== ユーティリティ ===== */
.text-center { text-align: center; }
.mt-8  { margin-top: 8px; }
.mt-16 { margin-top: 16px; }
.mt-24 { margin-top: 24px; }
.mt-40 { margin-top: 40px; }
.mb-40 { margin-bottom: 40px; }
