/* 自治体ニーズジャーナル — 報道系メディアの清潔なデザイン（白基調・和文タイポ・行間広め） */

:root {
  --ink: #1e2430;
  --ink-soft: #4a5364;
  --ink-faint: #7a8394;
  --line: #e3e6ec;
  --bg: #ffffff;
  --bg-soft: #f6f7f9;
  --accent: #1f5aa8;        /* 報道系の落ち着いた藍 */
  --accent-dark: #16437e;
  --accent-soft: #eaf1fa;
  --cta-strong: #b5541c;    /* 強CTAのみ暖色 */
  --max: 1080px;
  --max-prose: 720px;
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic Medium",
    "YuGothic", "Meiryo", system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: var(--bg);
  line-height: 1.9;
  font-size: 16px;
  font-feature-settings: "palt";
  overflow-wrap: anywhere;
}

img { max-width: 100%; height: auto; }
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: var(--max); margin: 0 auto; padding: 0 20px; }

/* ---------- ヘッダー ---------- */
.site-header {
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky; top: 0; z-index: 10;
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding-top: 14px; padding-bottom: 14px; flex-wrap: wrap;
}
.site-brand { display: flex; flex-direction: column; text-decoration: none; }
.site-brand:hover { text-decoration: none; }
.site-title { font-size: 1.25rem; font-weight: 700; color: var(--ink); letter-spacing: .02em; }
.site-tagline { font-size: .72rem; color: var(--ink-faint); }
.global-nav { display: flex; gap: 18px; align-items: center; }
.global-nav a { color: var(--ink-soft); font-size: .92rem; }
.global-nav a.active { color: var(--accent-dark); font-weight: 700; }
.global-nav .nav-cta {
  background: var(--accent); color: #fff; padding: 7px 16px; border-radius: 999px;
  font-weight: 700;
}
.global-nav .nav-cta:hover { background: var(--accent-dark); text-decoration: none; }

/* ---------- ヒーロー ---------- */
.hero { background: linear-gradient(180deg, var(--accent-soft), var(--bg)); padding: 64px 0 48px; }
.hero h1 { font-size: clamp(1.5rem, 4.2vw, 2.3rem); line-height: 1.5; letter-spacing: .02em; }
.hero-lead { max-width: var(--max-prose); margin-top: 20px; color: var(--ink-soft); }
.hero-actions { margin-top: 28px; display: flex; gap: 12px; flex-wrap: wrap; }
.sp-only { display: none; }

/* ---------- セクション ---------- */
.section { padding: 48px 0; }
.section-alt { background: var(--bg-soft); }
.section-title {
  font-size: 1.25rem; margin-bottom: 24px; padding-left: 12px;
  border-left: 4px solid var(--accent); line-height: 1.4;
}

/* ---------- カテゴリ ---------- */
.category-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 14px;
}
.category-card {
  display: flex; flex-direction: column; gap: 6px;
  border: 1px solid var(--line); border-radius: 10px; padding: 16px 18px;
  background: var(--bg); transition: border-color .15s, box-shadow .15s;
}
.category-card:hover { text-decoration: none; border-color: var(--accent); box-shadow: 0 2px 10px rgba(31,90,168,.08); }
.category-name { font-weight: 700; color: var(--ink); }
.category-desc { font-size: .8rem; color: var(--ink-faint); line-height: 1.7; }

/* ---------- 記事カード ---------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 18px; }
.card { border: 1px solid var(--line); border-radius: 10px; background: var(--bg); overflow: hidden; }
.card-link { display: block; padding: 18px 20px; color: inherit; height: 100%; }
.card-link:hover { text-decoration: none; background: var(--bg-soft); }
.card-meta { display: flex; align-items: center; gap: 10px; font-size: .78rem; color: var(--ink-faint); flex-wrap: wrap; }
.badge {
  display: inline-block; background: var(--accent-soft); color: var(--accent-dark);
  font-size: .74rem; font-weight: 700; padding: 2px 10px; border-radius: 999px;
}
.badge-draft { background: #fdeeee; color: #a33; }
.card-title { font-size: 1.02rem; line-height: 1.65; margin-top: 10px; }
.card-excerpt { font-size: .85rem; color: var(--ink-soft); margin-top: 8px; }

/* ---------- ボタン / CTA ---------- */
.btn {
  display: inline-block; padding: 11px 22px; border-radius: 8px;
  font-weight: 700; font-size: .95rem; line-height: 1.5; text-align: center;
}
.btn:hover { text-decoration: none; opacity: .92; }
.btn-light { background: var(--accent); color: #fff; }
.btn-mid { background: var(--bg); color: var(--accent-dark); border: 2px solid var(--accent); }
.btn-strong { background: var(--cta-strong); color: #fff; }
.btn-ghost { background: transparent; color: var(--accent-dark); border: 1px solid var(--line); }

.cta-block {
  margin: 48px 0 8px; padding: 28px 26px; border-radius: 12px;
  background: var(--bg-soft); border: 1px solid var(--line);
}
.cta-heading { font-size: 1.08rem; line-height: 1.6; }
.cta-lead { margin-top: 10px; font-size: .92rem; color: var(--ink-soft); }
.cta-actions { margin-top: 18px; display: flex; gap: 12px; flex-wrap: wrap; }
.cta-note { margin-top: 12px; font-size: .78rem; color: var(--ink-faint); }

.report-banner {
  background: var(--accent-soft); border-radius: 12px; padding: 32px 28px;
}
.report-banner h2 { font-size: 1.2rem; }
.report-banner p { margin-top: 10px; max-width: var(--max-prose); color: var(--ink-soft); }

/* ---------- ページ共通 ---------- */
.page-body { padding: 36px 20px 64px; }
.breadcrumb { font-size: .8rem; color: var(--ink-faint); margin-bottom: 20px; }
.breadcrumb span { margin: 0 4px; }
.page-header h1 { font-size: 1.55rem; line-height: 1.55; }
.page-desc { margin-top: 12px; color: var(--ink-soft); max-width: var(--max-prose); }
.empty-note {
  padding: 36px 24px; border: 1px dashed var(--line); border-radius: 10px;
  color: var(--ink-soft); text-align: center; margin-top: 8px;
}
.empty-note p + p { margin-top: 10px; }

/* ---------- 記事詳細 ---------- */
.article-body { max-width: calc(var(--max-prose) + 40px); }
.article-header { margin-bottom: 28px; }
.article-header h1 { font-size: 1.5rem; line-height: 1.6; margin-top: 12px; }
.article-munis { margin-top: 10px; font-size: .85rem; color: var(--ink-faint); }
.draft-banner {
  background: #fff7e8; border: 1px solid #ecd9ad; color: #7a5b12;
  padding: 10px 16px; border-radius: 8px; font-size: .85rem; margin-bottom: 20px;
}
.article-content h2 {
  font-size: 1.22rem; margin: 40px 0 14px; padding-bottom: 8px;
  border-bottom: 2px solid var(--accent-soft); line-height: 1.5;
}
.article-content h3 { font-size: 1.05rem; margin: 28px 0 10px; }
.article-content h4 { font-size: .98rem; margin: 22px 0 8px; }
.article-content p { margin: 14px 0; }
.article-content ul, .article-content ol { margin: 14px 0 14px 1.6em; }
.article-content li { margin: 6px 0; }
.article-content blockquote {
  margin: 18px 0; padding: 12px 18px; border-left: 4px solid var(--line);
  color: var(--ink-soft); background: var(--bg-soft); border-radius: 0 8px 8px 0;
}
.article-content hr { border: none; border-top: 1px solid var(--line); margin: 32px 0; }
.article-content pre {
  background: var(--bg-soft); border: 1px solid var(--line); border-radius: 8px;
  padding: 14px 16px; overflow-x: auto; font-size: .85rem; line-height: 1.7;
}
.article-content code { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: .9em; }

.source-block {
  margin-top: 40px; padding: 20px 22px; background: var(--bg-soft);
  border-radius: 10px; border: 1px solid var(--line);
}
.source-block h2 { font-size: 1rem; margin-bottom: 10px; }
.source-block ul { margin-left: 1.4em; font-size: .88rem; }
.source-block li { margin: 6px 0; overflow-wrap: anywhere; }
.source-note { margin-top: 10px; font-size: .78rem; color: var(--ink-faint); }
.related { margin-top: 48px; }

/* ---------- フォーム（レポート請求） ---------- */
.form-section { margin-top: 36px; max-width: var(--max-prose); }
.form-section h2 { font-size: 1.15rem; margin-bottom: 12px; }
.form-items { margin: 14px 0 20px 1.6em; }
.form-items li { margin: 6px 0; }
.req {
  display: inline-block; background: #fdeeee; color: #a33; font-size: .72rem;
  font-weight: 700; padding: 1px 8px; border-radius: 4px; margin-left: 6px; vertical-align: middle;
}
.form-embed-placeholder {
  border: 2px dashed var(--line); border-radius: 12px; padding: 40px 24px;
  text-align: center; color: var(--ink-soft); background: var(--bg-soft);
}
.form-embed-placeholder p + p { margin-top: 10px; font-size: .9rem; }
.form-embed { width: 100%; min-height: 900px; border: none; }

/* ---------- 静的ページ ---------- */
.prose { max-width: var(--max-prose); margin-top: 8px; }
.prose h2 { font-size: 1.15rem; margin: 34px 0 12px; padding-left: 10px; border-left: 4px solid var(--accent); line-height: 1.5; }
.prose p { margin: 12px 0; }
.prose ul { margin: 12px 0 12px 1.6em; }
.info-table { width: 100%; border-collapse: collapse; margin-top: 14px; font-size: .92rem; }
.info-table th, .info-table td { border: 1px solid var(--line); padding: 10px 14px; text-align: left; vertical-align: top; }
.info-table th { background: var(--bg-soft); white-space: nowrap; width: 9em; font-weight: 700; }
.contact-mail { font-size: 1.05rem; font-weight: 700; }

/* ---------- フッター ---------- */
.site-footer { border-top: 1px solid var(--line); background: var(--bg-soft); padding: 36px 0; margin-top: 24px; }
.footer-nav { display: flex; gap: 8px 22px; flex-wrap: wrap; font-size: .88rem; }
.footer-nav a { color: var(--ink-soft); }
.footer-note { margin-top: 16px; font-size: .78rem; color: var(--ink-faint); }
.copyright { margin-top: 10px; font-size: .78rem; color: var(--ink-faint); }

/* ---------- レスポンシブ ---------- */
@media (max-width: 640px) {
  body { font-size: 15.5px; }
  .sp-only { display: inline; }
  .hero { padding: 40px 0 32px; }
  .header-inner { flex-direction: column; align-items: flex-start; gap: 10px; }
  .global-nav { width: 100%; justify-content: flex-start; gap: 14px; }
  .card-grid, .category-grid { grid-template-columns: 1fr; }
  .info-table th { white-space: normal; width: auto; }
  .btn { width: 100%; }
  .cta-actions .btn, .hero-actions .btn { width: 100%; }
}
