@charset "UTF-8";
/* ============================================================
   jpmono.com — Templates (single / archive / page / search)
   tokens / base / components / sections の後に読まれる。
   ============================================================ */


/* ── Page hero (archive / page 共通) ─────────────────── */
.page-hero {
  padding-block: var(--space-16) var(--space-12);
  background: var(--bg-secondary);
  border-bottom: var(--border-thin);
}
@media (min-width: 1100px) { .page-hero { padding-block: var(--section-py-desktop) var(--space-16); } }

.page-hero__breadcrumb {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.page-hero__breadcrumb a { color: var(--ink-secondary); }
.page-hero__breadcrumb a:hover { color: var(--accent-red); }
.page-hero__breadcrumb__sep { color: var(--ink-muted); opacity: .6; }

.page-hero__eyebrow { margin-bottom: var(--space-3); }
.page-hero__title {
  font-family: var(--font-serif);
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-display);
  margin: 0 0 var(--space-4);
  text-wrap: pretty;
  max-width: 18ch;
}
.page-hero__desc {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--ink-secondary);
  margin: 0;
  max-width: 60ch;
}


/* ── Archive filter (chip bar) ───────────────────────── */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
  padding-block: var(--space-4);
  border-bottom: var(--border-thin);
}
.filter-bar__chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 8px 14px;
  border: var(--border-thin);
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  font-weight: var(--fw-medium);
  color: var(--ink-secondary);
  background: var(--bg-elevated);
  transition: border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.filter-chip:hover { color: var(--ink-primary); border-color: var(--ink-primary); }
.filter-chip.is-active {
  background: var(--ink-primary);
  border-color: var(--ink-primary);
  color: var(--ink-inverse);
}
.filter-count {
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
}


/* ── Archive grid (post listing) ─────────────────────── */
.archive-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12) var(--space-6);
}
@media (min-width: 640px)  { .archive-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px)  { .archive-grid { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1200px) { .archive-grid { grid-template-columns: repeat(4, 1fr); } }


/* ── Pagination ───────────────────────────────────────── */
.pagination {
  margin-top: var(--space-16);
  display: flex;
  justify-content: center;
  gap: var(--space-2);
}
.pagination a, .pagination span {
  min-width: 44px;
  height: 44px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-sans);
  font-size: var(--fs-button);
  font-weight: var(--fw-semi);
  color: var(--ink-primary);
  border: var(--border-thin);
  border-radius: var(--radius-button);
  background: var(--bg-elevated);
  transition: background var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
}
.pagination a:hover { background: var(--ink-primary); color: var(--ink-inverse); border-color: var(--ink-primary); }
.pagination .current {
  background: var(--ink-primary); color: var(--ink-inverse); border-color: var(--ink-primary);
}


/* ============================================================
   Single article (editorial layout)
   ============================================================ */
.single-article {
  padding-block: var(--space-12) var(--section-py-desktop);
}

.single-article__hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-4);
  margin-bottom: var(--space-12);
}
.single-article__eyebrow { color: var(--accent-red); }
.single-article__title {
  font-family: var(--font-serif);
  font-size: clamp(2rem, 4.5vw, 3.75rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-weight: var(--fw-medium);
  color: var(--ink-primary);
  margin: 0;
  text-wrap: balance;
  max-width: 22ch;
}
.single-article__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
}
.single-article__meta a { color: var(--ink-secondary); }
.single-article__meta a:hover { color: var(--accent-red); }

.single-article__featured {
  margin-bottom: var(--space-16);
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-card);
  background: var(--bg-secondary);
}
.single-article__featured img { width: 100%; height: 100%; object-fit: cover; }

/* 2026-05-25: 右 sticky aside を廃止し、本文は中央 1 カラム (読みやすい計測幅) に統一。 */
.single-article__layout {
  display: grid;
  grid-template-columns: minmax(0, 720px);
  justify-content: center;
}

/* 上部 CTA: TOP画像の直下に中央配置。購入意欲の高い読者を「どこで買えるか」へ誘導。 */
.single-article__cta-top {
  text-align: center;
  /* featured 画像 (margin-bottom: space-16) の直下に置くので上は詰め、下に本文との間隔 */
  margin: calc(-1 * var(--space-8)) 0 var(--space-12);
}
.single-article__buy-btn {
  /* .btn を継承しつつ朱の主アクション色で目立たせる */
  background: var(--accent-red);
  color: var(--ink-inverse, #fff);
  border-color: var(--accent-red);
}
.single-article__buy-btn:hover {
  background: var(--accent-red-dk, #93291f);
  border-color: var(--accent-red-dk, #93291f);
  color: var(--ink-inverse, #fff);
}
/* scroll 先がsticky headerに隠れない保険 */
#jpmono-buy { scroll-margin-top: 96px; }

.cta-card {
  padding: var(--space-6);
  background: var(--bg-elevated);
  border: var(--border-thin);
  border-radius: var(--radius-card);
}
.cta-card .eyebrow { display: block; margin-bottom: var(--space-3); }
.cta-card h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: var(--fw-medium);
  margin: 0 0 var(--space-3);
  line-height: 1.3;
}
.cta-card p {
  font-size: var(--fs-body);
  color: var(--ink-secondary);
  margin: 0 0 var(--space-6);
}
.cta-card .btn { width: 100%; }
.cta-card__meta {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: var(--border-thin);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
}


/* ── Prose (body content) ─────────────────────────────── */
/* Cocoon 親の .entry-content p / figcaption に薄い灰色 (#64748b 等) が
   仕込まれているため、prose 内では !important で打ち消して contrast を確保。 */
.prose {
  font-family: var(--font-sans);
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--ink-primary) !important;
}
.prose > * + * { margin-top: var(--space-6); }
.prose p,
.prose li,
.prose dd,
.prose dt { color: var(--ink-primary) !important; }
.prose figcaption { color: var(--ink-muted) !important; }
.prose h2 {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  line-height: 1.25;
  font-weight: var(--fw-medium);
  margin-top: var(--space-16);
  letter-spacing: -0.01em;
}
.prose h3 {
  font-family: var(--font-serif);
  font-size: 1.375rem;
  line-height: 1.3;
  font-weight: var(--fw-medium);
  margin-top: var(--space-12);
}
.prose p { max-width: var(--measure-max); color: var(--ink-primary); }
.prose a { text-decoration: underline; text-decoration-color: var(--border-strong); text-underline-offset: 3px; }
.prose a:hover { color: var(--accent-red); text-decoration-color: var(--accent-red); }
.prose strong { font-weight: var(--fw-semi); color: var(--ink-primary); }
.prose em { font-style: italic; }
.prose ul, .prose ol { margin-left: var(--space-6); }
.prose ul li, .prose ol li { list-style: revert; margin-bottom: var(--space-3); }
.prose figure { margin: var(--space-12) 0; }
.prose img { width: 100%; border-radius: var(--radius-card); }
.prose figcaption {
  text-align: center;
  margin-top: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
  font-style: italic;
}
.prose blockquote {
  margin: var(--space-12) 0;
  padding: var(--space-6) var(--space-8);
  background: var(--bg-secondary);
  border-left: 3px solid var(--accent-red);
  font-family: var(--font-serif);
  font-size: 1.5rem;
  line-height: 1.4;
  font-style: italic;
  color: var(--ink-primary);
  border-radius: 0 var(--radius-card) var(--radius-card) 0;
}
.prose blockquote p { font-family: inherit; color: inherit; }
.prose hr {
  border: 0;
  height: 1px;
  background: var(--border-subtle);
  margin: var(--space-16) auto;
  max-width: 80px;
}

/* WP TOC plus 互換 */
.prose #toc_container,
.prose .toc_white,
#toc_container {
  background: var(--bg-secondary) !important;
  border: var(--border-thin) !important;
  border-radius: var(--radius-card) !important;
  font-family: var(--font-sans) !important;
}


/* ── Related articles ───────────────────────────────── */
.related {
  margin-top: var(--section-py-desktop);
  padding-top: var(--space-16);
  border-top: var(--border-thin);
}
.related .grid { gap: var(--space-8) var(--space-6); }


/* ============================================================
   Region archive (storytelling intro)
   ============================================================ */
.region-intro {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  margin-bottom: var(--space-16);
}
@media (min-width: 1000px) {
  .region-intro {
    grid-template-columns: 1.1fr 1fr;
    gap: var(--space-16);
    align-items: center;
  }
}
.region-intro__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: var(--radius-card);
}
.region-intro__media img { width: 100%; height: 100%; object-fit: cover; }
.region-intro__body p {
  font-size: var(--fs-body-lg);
  line-height: var(--lh-body-lg);
  color: var(--ink-primary);
  max-width: 56ch;
}


/* ============================================================
   Search results
   ============================================================ */
.search-summary {
  margin-bottom: var(--space-12);
  font-family: var(--font-sans);
  color: var(--ink-secondary);
}
.search-summary strong {
  color: var(--ink-primary);
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: var(--fw-medium);
}
.search-no-results {
  padding-block: var(--section-py-desktop);
  text-align: center;
}
.search-no-results h2 {
  font-family: var(--font-serif);
  font-size: 2rem;
  margin: 0 0 var(--space-3);
}


/* ============================================================
   404
   ============================================================ */
.not-found {
  padding-block: var(--section-py-large);
  text-align: center;
}
.not-found__num {
  font-family: var(--font-serif);
  font-size: clamp(6rem, 15vw, 12rem);
  line-height: 1;
  color: var(--accent-red);
  margin: 0;
  font-weight: var(--fw-medium);
}


/* ============================================================
   Affiliate disclosure inline
   ============================================================ */
.affiliate-note {
  margin-top: var(--space-6);
  padding: var(--space-3) var(--space-4);
  border-left: 2px solid var(--border-subtle);
  font-size: var(--fs-caption);
  color: var(--ink-muted);
  font-family: var(--font-sans);
}


/* ============================================================
   Interactive Japan map (/regions/ 上部)
   ============================================================ */
.region-map {
  max-width: 560px;
  margin: 0 auto;
}
.region-map__svg svg { width: 100%; height: auto; display: block; }
/* 県の塗り: <g class="… prefecture"> に fill を当て、内側 polygon が継承する */
.region-map .prefecture {
  fill: #E7DFD3;                 /* 投稿あり県の既定 (温かいグレー) */
  stroke: var(--bg-primary);
  stroke-width: 1.2;
  transition: fill var(--dur-fast) var(--ease-out);
}
.region-map .prefecture.is-disabled { fill: #EFEAE1; opacity: .65; }   /* 投稿なし: 淡色・不可 */
.region-map .prefecture.is-linked { cursor: pointer; }
.region-map .prefecture.is-linked:hover,
.region-map .prefecture.is-linked:focus { fill: var(--accent-red); outline: none; }
.region-map .prefecture.is-linked:focus-visible { fill: var(--accent-red-dk); }
.region-map__caption {
  text-align: center;
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: var(--fw-semi);
  letter-spacing: 0.02em;
  color: var(--ink-secondary);
  margin: var(--space-3) 0 var(--space-12);
  min-height: 1.5em;
}
@media (min-width: 1000px) { .region-map { max-width: 620px; } }
