/* =========================================================
   Q&A アーカイブ／カテゴリー（archive-qa.php / taxonomy-qa_category.php）
   デザインは /blog/（page-blog.php / blog-hub.css）と共通化。
   このファイルは QA固有（アコーディオン・Q/Aバッジ・件数・戻る/ページネーション）のみ。
   配色/フォント等のトークン(--accent 等)は blog-hub.css の .blog-hub スコープを継承。
   2026-07-01 リデザイン（旧版は qa-archive.css.bak-* にバックアップ）
   ========================================================= */

/* サイドバーを消して1カラム（レイアウト・blog-hub非依存） */
.l-archive-qa aside#sidebar { display: none; }
.-sidebar-on .l-archive-qa.l-mainContent,
.l-archive-qa.l-mainContent { width: 100%; }

/* カテゴリチップ（タグクラウド）の下に余白を少し追加 */
.blog-hub .bh-cats { margin-bottom: 40px; }

/* セクション（アンカージャンプのオフセット）＋見出しの件数 */
.blog-hub .qa-section { scroll-margin-top: 90px; }
.blog-hub .bh-sec__title .qa-count {
	font-family: var(--font-en);
	font-size: 13px; font-weight: 500;
	color: var(--fg-dim); margin-left: 10px;
}

/* ---------- アコーディオン（1問） ---------- */
.blog-hub .qa-list { display: flex; flex-direction: column; gap: 12px; }
.blog-hub .qa-item {
	background: var(--bg);
	border: 1px solid var(--border);
	border-radius: var(--radius);
	overflow: hidden;
	transition: border-color .2s, box-shadow .2s;
}
.blog-hub .qa-item[open] { border-color: var(--accent); box-shadow: 0 10px 24px var(--accent-shadow); }

.blog-hub .qa-item__q {
	list-style: none; cursor: pointer;
	display: flex; align-items: center; gap: 14px;
	padding: 18px 20px;
	font-size: 15px; font-weight: 600; line-height: 1.6;
	color: var(--fg);
}
.blog-hub .qa-item__q::-webkit-details-marker { display: none; }
.blog-hub .qa-item__title { flex: 1; }

.blog-hub .qa-badge {
	flex: 0 0 auto;
	display: inline-grid; place-items: center;
	width: 30px; height: 30px;
	border-radius: 9px;
	background: var(--accent); color: #fff;
	font-family: var(--font-en); font-weight: 700; font-size: 15px; line-height: 1;
}
.blog-hub .qa-badge--a { background: var(--cv-orange); }

.blog-hub .qa-item__chevron {
	flex: 0 0 auto;
	width: 11px; height: 11px;
	border-right: 2px solid var(--accent);
	border-bottom: 2px solid var(--accent);
	transform: rotate(45deg);
	transition: transform .2s;
	margin-top: -3px;
}
.blog-hub .qa-item[open] .qa-item__chevron { transform: rotate(-135deg); margin-top: 3px; }

.blog-hub .qa-item__a { display: flex; gap: 14px; padding: 2px 20px 20px; }
.blog-hub .qa-item__body { flex: 1; }
.blog-hub .qa-item__excerpt { margin: 0 0 12px; font-size: 14px; line-height: 1.9; color: var(--fg-muted); }
.blog-hub .qa-item__more { margin: 0; }
.blog-hub .qa-item__more a { color: var(--accent); font-weight: 600; font-size: 13px; }
.blog-hub .qa-item__more a:hover { color: var(--cv-orange); }

/* ---------- パンくず（任意） ---------- */
.blog-hub .qa-breadcrumb { font-size: 12px; color: var(--fg-dim); margin: 0 0 18px; }
.blog-hub .qa-breadcrumb a { color: var(--accent); }
.blog-hub .qa-breadcrumb__sep { margin: 0 6px; }

/* ---------- 戻るリンク・ページネーション（taxonomy） ---------- */
.blog-hub .qa-back { margin-top: 36px; }
.blog-hub .qa-back a { color: var(--accent); font-weight: 600; }
.blog-hub .qa-back a:hover { color: var(--cv-orange); }

.blog-hub .custom-pagination { margin-top: 40px; text-align: center; }
.blog-hub .custom-pagination .page-numbers {
	display: inline-block; margin: 0 4px; padding: 8px 13px;
	background: var(--bg-soft); border: 1px solid var(--border);
	border-radius: var(--radius-sm);
	font-family: var(--font-en); font-size: 14px;
	color: var(--fg); text-decoration: none; transition: border-color .2s, color .2s, background .2s;
}
.blog-hub .custom-pagination .page-numbers:hover { border-color: var(--accent); color: var(--accent); }
.blog-hub .custom-pagination .current { background: var(--accent); border-color: var(--accent); color: #fff; }

/* ---------- SP ---------- */
@media screen and (max-width: 768px) {
	.blog-hub .qa-item__q { padding: 15px 16px; gap: 10px; }
	.blog-hub .qa-item__a { padding: 2px 16px 18px; gap: 10px; }
	.blog-hub .qa-badge { width: 26px; height: 26px; font-size: 13px; border-radius: 8px; }
}
