/* 記事ページ（問題ページ・ハブページ）用 — 演習エンジンには影響しない */
.page-body { max-width: 860px; margin: 0 auto; padding: 0 18px; }
.page-header { padding: 18px 0; border-bottom: 1px solid var(--line, #1d2733); }
.page-logo { font-weight: 700; letter-spacing: .08em; text-decoration: none; color: inherit; }
.page-main { padding: 24px 0 48px; line-height: 1.9; }
.page-main h1 { font-size: 1.35rem; line-height: 1.6; margin: 12px 0 20px; }
.page-main h2 { font-size: 1.1rem; margin: 32px 0 12px; }
.breadcrumb { font-size: .8rem; opacity: .75; }
.breadcrumb a { color: inherit; }
.q-meta { display: flex; gap: 10px; font-size: .78rem; opacity: .8; margin-bottom: 14px; }
.q-choices { list-style: none; padding: 0; }
.q-choices li { border: 1px solid var(--line, #1d2733); border-radius: 8px; padding: 10px 14px; margin: 8px 0; }
.q-answer { margin: 18px 0; border: 1px solid var(--accent, #34d399); border-radius: 10px; }
.q-answer summary { cursor: pointer; padding: 12px 16px; font-weight: 700; color: var(--accent, #34d399); }
.q-answer .inner { padding: 0 16px 16px; }
.q-nav { display: flex; justify-content: space-between; gap: 12px; margin: 24px 0; font-size: .9rem; }
.related { font-size: .9rem; }
.cta-box { text-align: center; margin: 28px 0; }
.page-footer { border-top: 1px solid var(--line, #1d2733); padding: 20px 0 40px; font-size: .78rem; opacity: .85; }
.hub-nav, .site-nav { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 10px; }
.hub-nav a, .site-nav a { color: inherit; }
.domain-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.domain-table th, .domain-table td { border: 1px solid var(--line, #1d2733); padding: 8px 10px; text-align: left; }
.q-list { padding-left: 1.2em; }
.q-list li { margin: 6px 0; }

/* 関連サービスリンク（問題ページの解説最下段） */
.svc-links { margin-top: 14px; padding-top: 10px; border-top: 1px dashed var(--line, #1d2733); font-size: .85rem; }
.official-link a { font-weight: 700; }
