/*
Template:easel
Theme Name:canvas on EASEL
Version: 1.1.0
*/
/* ================================================================
   硝子窓の向こう — 静的プロトタイプ
   style.css

   ▼ ファイル構成方針
   現時点は単一ファイルで管理。WP テーマ実装時に物理分割を行う。
   各セクションの境界をコメントで明示し、将来の切り出しを容易にする。

   ▼ セクション構成
   [1] FOUNDATION  — Reset / Base
   [2] LAYOUT      — Site wrapper / Kanban / Content
   [3] NAV         — Kanban navigation
   [4] PAGE        — 固定ページ共通（about, links 等）
   [5] TOP         — トップページ専用ウィジェット
   [6] WORK        — 作品個別ページ
   [7] ARCHIVE     — 投稿一覧（日記一覧）
   [8] SINGLE      — 投稿個別（日記記事）
   [9] MEMO        — メモページ
  [10] UTIL        — ハンバーガー / ページャ等
  [11] RESPONSIVE

   ▼ WP テーマ分割の目安（実装時の参考）
   PAGE → page.php
   ARCHIVE → archive.php（single.php と同じ CSS を読めばよい）
   SINGLE → single.php
   MEMO → page-{slug}.php で固定ページ運用
   ================================================================ */


/* ================================================================
   [1] FOUNDATION — Reset / Base
   ================================================================ */

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

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

:root {
  --c-page-bg:          #c2cdd8;
  --c-sidebar-bg:       #f7f4f1;
  --c-content-bg:       #faf8f6;
  --c-card-bg:          #f7f4f1;
  --c-surface-soft:     #f0ece7;
  --c-surface-muted:    #e8e2da;
  --c-text-main:        #333333;
  --c-text-strong:      #1a1a1a;
  --c-text-secondary:   #666666;
  --c-text-muted:       #999999;
  --c-accent:           #3F67B1;
  --c-accent-dark:      #2F52A0;
  --c-accent-rgb:       63, 103, 177;
  --c-spot:             #C4904A;
  --c-spot-rgb:         196, 144, 74;
  --c-border:           #d9d2ca;
  --c-border-rgb:       217, 210, 202;
  --c-heading-band:     #e3dfdb;
  --c-heading-band-rgb: 227, 223, 219;
}

html {
  background: var(--c-page-bg);
}

body {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 400;
  color: #333;
  background: var(--c-page-bg);
  line-height: 1.85;
  -webkit-font-smoothing: antialiased;
  scrollbar-color: rgba(63, 103, 177, 0.25) var(--c-page-bg);
  scrollbar-width: thin;
}

::-webkit-scrollbar {
  width: 8px;
}

::-webkit-scrollbar-track {
  background: var(--c-page-bg);
}

::-webkit-scrollbar-thumb {
  background: rgba(63, 103, 177, 0.28);
  border-radius: 4px;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: var(--c-accent);
  text-decoration: none;
}

a:hover {
  color: #3d5fa0;
}


/* ================================================================
   [2] LAYOUT — Site wrapper / Kanban / Content
   ================================================================ */

.site {
  display: flex;
  max-width: 1340px;
  margin: 0 auto;
  min-height: 100vh;
}

/* 左帯（看板） */
.kanban {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
  width: 300px;
  flex-shrink: 0;
  background: #fff;
  border-right: 1px solid #cbd5e8;
  display: flex;
  flex-direction: column;
}

/* 本文エリア */
.content {
  flex: 1;
  min-width: 0;
  background: var(--c-content-bg);
}


/* ================================================================
   [3] NAV — Kanban 看板ナビゲーション
   ================================================================ */

/* ビジュアル（写真） */
.kanban-visual {
  position: relative;
  line-height: 0;
  overflow: hidden;
  height: 360px;
  flex-shrink: 0;
}

.kanban-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.mobile-site-hero {
  display: none;
}

.mobile-site-hero img,
.mobile-site-hero--placeholder {
  width: 100%;
  height: 100%;
  display: block;
}

/* サイト名 */
.kanban-name {
  padding: 14px 20px 22px;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: #333;
  text-align: center;
}

/* ナビリスト */
.kanban-nav {
  display: flex;
  flex-direction: column;
  padding: 0 0 8px;
}

/*
 * 4点星 SVG を ::before で管理
 * 常時 width 分を確保 → hover 時に文字位置がズレない
 * 通常: border-bottom で行の輪郭
 * hover: 薄背景 + アウトライン星
 * current: 左バー + 塗り星 + bold + 濃い文字色
 */
.kanban-nav a {
  display: flex;
  align-items: center;
  padding: 11px 16px;
  font-size: 0.85rem;
  color: var(--c-text-main);
  letter-spacing: 0.06em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.10);
  transition: color 0.2s, background-color 0.2s;
}

.kanban-nav a::before {
  content: '';
  flex-shrink: 0;
  width: 12px;
  height: 12px;
  margin-right: 8px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 0.5 L7.1 4.9 L11.5 6 L7.1 7.1 L6 11.5 L4.9 7.1 L0.5 6 L4.9 4.9 Z' fill='none' stroke='%233F67B1' stroke-width='1.0'/%3E%3C/svg%3E");
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity 0.2s ease, transform 0.22s ease;
}

.kanban-nav a:hover,
.kanban-nav a:focus-visible {
  color: var(--c-accent-dark);
  background-color: rgba(var(--c-accent-rgb), 0.12);
}

.kanban-nav a:hover::before,
.kanban-nav a:focus-visible::before {
  opacity: 1;
  transform: translateX(0);
}

.kanban-nav a[aria-current="page"] {
  color: var(--c-text-strong);
  font-weight: 600;
  background-color: rgba(var(--c-accent-rgb), 0.10);
  box-shadow: inset 3px 0 0 var(--c-accent);
}

.kanban-nav a[aria-current="page"]::before {
  opacity: 1;
  transform: translateX(0);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 0.5 L7.1 4.9 L11.5 6 L7.1 7.1 L6 11.5 L4.9 7.1 L0.5 6 L4.9 4.9 Z' fill='%233F67B1'/%3E%3C/svg%3E");
  transition: none;
}

/* since / copyright */
.kanban-counter {
  margin: 0;
  padding: 10px 0 8px;
  text-align: center;
}

.kanban-counter__num {
  font-family: 'Lato', 'DM Mono', ui-monospace, monospace;
  font-size: 0.72rem;
  font-weight: 300;
  letter-spacing: 0.22em;
  font-variant-numeric: tabular-nums;
  color: #7a85a3;
}

.kanban-note {
  margin-top: auto;
  padding: 6px 0 20px;
  font-size: 0.7rem;
  color: #aaa;
  text-align: center;
}

.kanban-external {
    padding: 18px 18px 14px;
    border-top: 0;
  }
  
.kanban-external__list {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: 16px;
  }
  
.kanban-external__item {
    flex: 0 0 auto;
  }
  
.kanban-external__link {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 6px 2px;
    border: 0;
    border-radius: 0;
    background: transparent;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.kanban-external__link img {
    display: block;
    width: auto;
    max-width: 100%;
    height: 24px;
  }

.kanban-external__link:not(.is-placeholder):hover,
.kanban-external__link:not(.is-placeholder):focus-visible {
  opacity: 0.72;
  transform: translateY(-1px);
  outline: none;
}

.kanban-external__link.is-placeholder {
  opacity: 0.9;
}

/* サイトフッター（本文エリア下部） */
.site-footer {
  padding: 18px 48px 24px;
  border-top: 1px solid #dce0ec;
  font-size: 0.75rem;
  color: #aaa;
  background: linear-gradient(180deg, rgba(247, 249, 251, 0) 0%, rgba(240, 244, 250, 0.5) 100%);
}


/* ================================================================
   [4] PAGE — 固定ページ共通
        WP: page.php / page-about.php / page-links.php etc.
   ================================================================ */

/* 見出し（固定ページ・トップ共通）
 * WP化時: h2 に chapter-title クラスを手動付与、または
 *         .page-body h2 { ... } でスコープを絞る
 * 左帯（4px）＋アイボリー薄面でセクションの頭として立たせる */
.chapter-title {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--c-text-strong);
  margin-bottom: 24px;
  padding: 6px 16px 6px 10px;
  border-left: 3px solid var(--c-accent);
  border-radius: 2px;
  background: rgba(232, 226, 212, 0.72);
}

.chapter-title::before {
  content: '';
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-accent);
}

/* 固定ページ本文ラッパー
 * WP: page.php の <?php the_content() ?> を囲むラッパー div */
.page-body {
  flex: 1;
  padding: 38px 48px 40px;
}

.page-body .chapter-title:first-child {
  margin-top: 0;
}

.page-body .chapter-title {
  margin-top: 48px;
}

/* 固定ページ本文 <p>
 * NOTE: .entry-content p とは別定義。
 *       WP 投稿本文には .entry-content を使い、このスタイルを汚染しない */
.page-body > p,
.page-body > section > p {
  font-size: 0.88rem;
  color: #444;
  line-height: 2;
  margin-bottom: 12px;
  padding-left: 16px;   /* 章見出し左バーの内側から始める */
}

.page-body > p:last-child,
.page-body > section > p:last-child {
  margin-bottom: 0;
}

/* 注意書き・補足 */
.page-note {
  font-size: 0.8rem;
  color: #888;
  margin-top: 8px;
}

/* ページ導入文 — h1 直下の補助テキスト */
.page-lead {
  font-size: 0.84rem;
  color: #666;
  line-height: 1.9;
  margin-top: 10px;
}

/* ================================================================
   [4b] CONTACT — Contact Form 7 フォーム
   .cf7-wrapper スコープで CF7 デフォルトスタイルを上書きする
   ================================================================ */

.cf7-wrapper {
  margin-top: 24px;
}

/* フィールドグループ */
.cf7-wrapper .canvas-field-group {
  margin-bottom: 20px;
}

.cf7-wrapper .canvas-field-group--submit {
  margin-top: 16px;
}

/*
 * CF7 の wpautop 対策:
 * CF7 はフォームテンプレートの改行を <br> に変換し、ブロックを <p> で囲む。
 * この <p> のデフォルトマージンと <br> がラベル↔入力欄の余白を広げるため除去する。
 */
.cf7-wrapper .canvas-field-group p {
  margin: 0;
  padding: 0;
}
.cf7-wrapper .canvas-field-group p br {
  display: none;
}

/* ラベル */
.cf7-wrapper .canvas-label {
  display: block;
  font-size: 0.84rem;
  color: #555;
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}

/* 必須マーク */
.cf7-wrapper .canvas-required {
  color: #b94040;
  margin-left: 3px;
  font-size: 0.75rem;
  vertical-align: 0.06em;
}

/* CF7 が各フィールドを包む span をブロックに戻してラベルとの隙間をなくす */
.cf7-wrapper .wpcf7-form-control-wrap {
  display: block;
}

/* 入力フィールド共通（submit 以外） */
.cf7-wrapper .wpcf7-form-control:not([type="submit"]) {
  display: block;
  width: 100%;
  padding: 7px 10px;
  background: #fff;
  border: 1px solid var(--c-border);
  border-radius: 3px;
  font-family: inherit;
  font-size: 0.88rem;
  color: var(--c-text-main);
  line-height: 1.6;
  transition: border-color 0.18s, outline-color 0.18s;
  -webkit-appearance: none;
  appearance: none;
}

/* 1行入力（お名前・メールアドレス・件名）はコンパクト幅 */
.cf7-wrapper .wpcf7-text,
.cf7-wrapper .wpcf7-email {
  max-width: 440px;
}

.cf7-wrapper .wpcf7-form-control:not([type="submit"]):focus {
  outline: 2px solid rgba(var(--c-accent-rgb), 0.38);
  outline-offset: 1px;
  border-color: rgba(var(--c-accent-rgb), 0.48);
}

/* textarea — 全幅不要、縦リサイズのみ */
.cf7-wrapper .wpcf7-textarea {
  max-width: 600px;
  min-height: 150px;
  padding: 8px 10px;
  resize: vertical;
}

/* バリデーションエラー付きフィールド */
.cf7-wrapper .wpcf7-not-valid {
  border-color: rgba(185, 64, 64, 0.5);
}

/* バリデーションエラーテキスト */
.cf7-wrapper .wpcf7-not-valid-tip {
  display: block;
  margin-top: 4px;
  font-size: 0.78rem;
  color: #b94040;
  line-height: 1.5;
}

/* 送信ボタン — 塗りつぶしで押下対象として明確にする */
.cf7-wrapper .wpcf7-submit {
  display: inline-block;
  padding: 9px 32px 10px;
  font-family: inherit;
  font-size: 0.86rem;
  letter-spacing: 0.06em;
  color: #fff;
  background: var(--c-accent);
  border: 1.5px solid var(--c-accent);
  border-radius: 3px;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}

.cf7-wrapper .wpcf7-submit:hover {
  background: var(--c-accent-dark);
  border-color: var(--c-accent-dark);
}

.cf7-wrapper .wpcf7-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* レスポンスメッセージ共通 */
.cf7-wrapper .wpcf7-response-output {
  margin-top: 20px;
  padding: 12px 16px;
  border-radius: 3px;
  font-size: 0.84rem;
  line-height: 1.7;
}

/* 送信成功 */
.cf7-wrapper .wpcf7.sent .wpcf7-response-output {
  border: 1px solid rgba(var(--c-accent-rgb), 0.32);
  background: rgba(var(--c-accent-rgb), 0.04);
  color: var(--c-accent-dark);
}

/* バリデーションエラー / 送信失敗 / スパム */
.cf7-wrapper .wpcf7.failed     .wpcf7-response-output,
.cf7-wrapper .wpcf7.invalid    .wpcf7-response-output,
.cf7-wrapper .wpcf7.unaccepted .wpcf7-response-output,
.cf7-wrapper .wpcf7.spam       .wpcf7-response-output {
  border: 1px solid rgba(185, 64, 64, 0.32);
  background: rgba(185, 64, 64, 0.04);
  color: #b94040;
}

/* 終端線 — コンテンツの視覚的終了を示す */
.page-rule {
  border: none;
  border-top: 1px solid var(--c-border);
  margin: 24px 0 20px;
}

/* 回遊導線 — 固定ページ下部の他ページリンク */
.page-bottom-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 20px;
  padding-bottom: 8px;
}

.page-bottom-nav a {
  font-size: 0.8rem;
  color: var(--c-text-muted);
  border-bottom: 1px dotted currentColor;
  padding-bottom: 1px;
  white-space: nowrap;
  transition: color 0.18s;
}

.page-bottom-nav a:hover {
  color: var(--c-text-secondary);
}

/* リンクリスト（about, links ページなど）*/
.link-list {
  list-style: none;
  margin-top: 12px;
  font-size: 0.84rem;
  padding-left: 16px;
}

.link-list li + li {
  margin-top: 4px;
}

.link-list a {
  border-bottom: 1px dotted #a4aecb;
  padding-bottom: 1px;
}


/* ================================================================
   [5] TOP — トップページ専用ウィジェット
        WP: front-page.php / home.php
   ================================================================ */

/* ごあいさつ */
.top-upper {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  column-gap: 0;
  align-items: start;
}

.top-upper__main {
  min-width: 0;
}

.top-upper__main > section + section {
  margin-top: 12px;
}

.top-upper__side {
  padding: 42px 36px 0 8px;
}

.section-greeting {
  padding: 28px 48px 16px;
}

.section-greeting p {
  font-size: 0.88rem;
  color: #444;
  line-height: 2;
  padding-left: 16px;
}

/* 更新履歴 */
.section-update {
  padding: 0 48px 28px;
}

.log-scroll {
  border: 1px solid rgba(63, 103, 177, 0.18);
  background: #f0f5fc;   /* body 背景 #c8d4e8 の極薄版。白に近いが青みを残す */
  padding: 12px 20px;
  max-height: 118px;
  overflow-y: auto;
}

/* WP 化時: カスタムHTMLブロックまたはウィジェットで出力
 * <ul class="log-list"> / <li class="log-entry"> / <time> で構成 */
.log-list {
  list-style: none;
  font-size: 0.80rem;
}

.log-entry {
  display: flex;
  gap: 18px;
  padding: 6px 0;
}

.log-entry + .log-entry {
  border-top: 1px dotted #e0dbc8;
}

.log-date {
  flex-shrink: 0;
  width: 7.4em;
  color: #8e9095;
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
}

.log-text {
  color: #444;
}

/* スクロールバー */
.log-scroll::-webkit-scrollbar { width: 6px; }
.log-scroll::-webkit-scrollbar-track { background: #e8eef8; }
.log-scroll::-webkit-scrollbar-thumb { background: #c0cedf; }

.section-memo-brief {
  position: relative;
  padding: 20px 16px 14px;
  background: #fffff8;
  background-image:
    repeating-linear-gradient(
      transparent 0px,
      transparent 23px,
      rgba(160, 180, 200, 0.18) 23px,
      rgba(160, 180, 200, 0.18) 24px
    );
  background-position: 0 19px;
  border: none;
  box-shadow:
    1px 2px 6px rgba(80, 70, 50, 0.10),
    0 0 0 1px rgba(180, 170, 150, 0.22);
  transform: rotate(0.7deg);
}

/* テープ風アクセント */
.section-memo-brief::before {
  content: "";
  position: absolute;
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 12px;
  background: rgba(200, 210, 190, 0.50);
  border-radius: 1px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.memo-brief-label {
  font-size: 0.70rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: #8a8070;
}

.memo-brief-date {
  display: block;
  margin-top: 4px;
  font-size: 0.72rem;
  font-variant-numeric: tabular-nums;
  color: #a09888;
}

.memo-brief-text {
  display: -webkit-box;
  margin-top: 6px;
  overflow: hidden;
  font-size: 0.78rem;
  line-height: 1.72;
  color: #4a4540;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
}

.memo-brief-more {
  margin-top: 8px;
  font-size: 0.72rem;
  line-height: 1.6;
  text-align: right;
}

.memo-brief-more a {
  color: #908878;
  border-bottom: 1px dotted rgba(120, 110, 90, 0.36);
}

.memo-brief-more a:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
}

/* 代表作 / 特集作品
 * WP 化時: カスタムフィールドまたはショートコードで出力 */
.section-work {
  padding: 36px 48px 46px;
  border-top: 1px solid var(--c-border);
}

.section-work.section-work--primary {
  padding-top: 30px;
  border-top: 0;
}

/* 作品ブロックの役割補足テキスト
 * WP化時: カスタムフィールドまたはブロックの説明テキストとして出力 */
.work-lead {
  margin-top: 4px;
  margin-bottom: 12px;
  font-size: 0.82rem;
  color: #888;
}

.section-work--primary .work-lead {
  margin-bottom: 16px;
}

.work-entrance {
  margin-top: 4px;
}

.work-link {
  display: flex;
  flex-direction: row;
  gap: 24px;
  align-items: flex-start;
  color: inherit;
}

.work-link:hover .work-banner img {
  opacity: 0.85;
}

.work-link:hover .work-title {
  color: var(--c-accent);
}

.work-banner {
  flex-shrink: 0;
  width: 400px;
  height: 134px;
  overflow: hidden;
  line-height: 0;
  border: 1px solid #cfd8ec;
  box-shadow: 0 2px 14px rgba(20, 50, 90, 0.08);
}

.work-banner img {
  width: 100%;
  transition: opacity 0.3s;
}

.work-info {
  flex: 1;
  padding-top: 8px;
}

.work-title {
  font-size: 1.2rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--c-text-strong);
  margin-bottom: 6px;
  transition: color 0.2s;
}

.work-genre {
  font-size: 0.76rem;
  color: #999;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}

.work-desc {
  font-size: 0.87rem;
  color: #444;
  line-height: 2.0;
}

/* 一覧へのリンク（「作品ページへ進む →」）*/
.work-more {
  margin-top: 20px;
}

.section-work--primary .work-more {
  margin-top: 24px;
}

.work-more a {
  display: inline-block;
  padding: 8px 22px 9px;
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  color: var(--c-accent);
  border: 1.5px solid var(--c-accent);
  border-radius: 3px;
  transition: background 0.2s, color 0.2s;
}

.work-more a:hover {
  background: var(--c-accent);
  color: #fff;
}

/* 次回イベント
   .event-body は現行トップで使っている wrapper。
   ここより下の旧 .event-* family とは責務を分けて読むこと。 */
.section-event {
  padding: 0 48px 30px;
}

.event-body {
  font-size: 0.88rem;
  max-width: 860px;
}

@media (max-width: 680px) {
  .event-body {
    max-width: 100%;
  }
}

/* legacy event UI layer
   現行テンプレート / plugin 出力では未使用の旧イベント UI 候補。
   削除判断は後段トーン調整レイヤーの参照整理とセットで行う。 */
.event-name {
  font-weight: 700;
  font-size: 1.08rem;
  margin-bottom: 6px;
  color: var(--c-text-strong);
}

.event-detail {
  color: var(--c-text-main);
  line-height: 1.85;
}

.event-detail p {
  margin: 0;
}

.event-detail p + p {
  margin-top: 4px;
}

.event-status-note {
  font-size: 0.78rem;
  color: var(--c-accent);
  margin-top: 4px;
}

.event-card--next {
  background: rgba(var(--c-accent-rgb), 0.06);
  border-left-width: 4px;
  box-shadow: 0 8px 24px rgba(26, 46, 78, 0.06);
}

.event-card-label {
  margin: 0 0 10px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--c-accent-dark);
}

.event-card--next .event-name {
  font-size: 1.16rem;
  margin-bottom: 8px;
}

/* still-used fallback
   .cen-* は plugin compact list の現役 class。
   style.css 側では共通 fallback のみを持ち、offline の本番見た目は offline-books.css を正本にする。 */
.cen-upcoming-list,
.cen-past-list {
  list-style: none;
  margin: 0;
  padding: 10px 12px;
  border: 1px solid rgba(var(--c-accent-rgb), 0.18);
  background: rgba(var(--c-accent-rgb), 0.05);
  border-radius: 4px;
}

.cen-upcoming-item,
.cen-past-item {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 6px 8px;
  font-size: 0.74rem;
  color: var(--c-text-secondary);
  line-height: 1.55;
  padding: 4px 0;
}

.cen-upcoming-date,
.cen-past-date {
  flex-shrink: 0;
  min-width: 5.8em;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.02em;
  color: var(--c-accent);
}

.cen-upcoming-name,
.cen-past-name {
  color: var(--c-text-secondary);
}

.cen-upcoming-name a {
  color: inherit;
  text-decoration: none;
}

.cen-upcoming-name a:hover {
  color: var(--c-accent);
}

.cen-upcoming-venue,
.cen-past-venue {
  color: var(--c-text-muted);
}

.cen-upcoming-venue::before,
.cen-past-venue::before {
  content: '／';
  margin-right: 2px;
}

.cen-upcoming-space,
.cen-past-space {
  color: var(--c-text-muted);
  font-size: 0.70rem;
}

/* ── compact モード fallback ── */
/* plugin の compact markup を offline 以外で単体利用しても崩れない最低限だけ残す。
   .ob-event-* は現役 class だが、offline 固有の shell / 2 カラム配置 / 本番見た目は
   offline-books.css を正本にする。 */
.ob-event-bar {
  display: block;
  padding: 12px 16px;
  margin-bottom: 28px;
  border: 1px solid rgba(var(--c-accent-rgb), 0.18);
  background: rgba(var(--c-accent-rgb), 0.05);
  border-radius: 4px;
}

.ob-event-next-card {
  display: flex;
  gap: 10px 14px;
  align-items: flex-start;
}

.ob-event-next-card__body {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.ob-event-bar-badge {
  flex-shrink: 0;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  color: var(--c-accent-dark);
  background: rgba(var(--c-accent-rgb), 0.14);
  border: 1px solid rgba(var(--c-accent-rgb), 0.35);
  padding: 2px 9px 3px;
  border-radius: 3px;
}

.ob-event-bar-name {
  font-weight: 600;
  font-size: 0.96rem;
  color: var(--c-text-strong);
}

.ob-event-next-card__details {
  margin: 0;
  display: grid;
  gap: 0;
}

.ob-event-next-card__detail-row {
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 2px 0;
  font-size: 0.82rem;
  line-height: 1.65;
}

.ob-event-next-card__detail-row dt {
  flex-shrink: 0;
  width: 4.8em;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--c-text-muted);
}

.ob-event-next-card__detail-row dd {
  margin: 0;
  color: var(--c-text-secondary);
}

.ob-event-next-card__detail-row--notice dd {
  color: var(--c-accent-dark);
  font-weight: 600;
}

.ob-event-bar-name a {
  color: inherit;
  text-decoration: none;
}

.ob-event-bar-name a:hover {
  color: var(--c-accent);
}

.ob-event-subheading {
  margin: 14px 0 6px;
  font-size: 0.70rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--c-text-secondary);
}

.ob-event-bar .cen-upcoming-list,
.ob-event-bar .cen-past-list {
  margin-top: 0;
}

/* 管理人 */
.section-profile {
  padding: 8px 48px 40px;
}

.profile-card {
  max-width: 680px;
  margin: 0 auto;
  background: var(--c-surface-soft);
  border: 1px solid var(--c-border);
  border-radius: 8px;
  padding: 16px 20px 14px;
}

.profile-body {
  display: flex;
  gap: 0;
  align-items: center;
}

.profile-icon {
  flex-shrink: 0;
  padding-right: 18px;
}

.profile-icon img {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  opacity: 0.9;
}

.profile-text {
  flex: 1;
  position: relative;
  padding-left: 16px;
}

.profile-text::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 1px;
  background: rgba(var(--c-accent-rgb), 0.28);
}

.profile-name {
  font-size: 0.92rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-bottom: 3px;
  color: var(--c-text-main);
}

.profile-text p {
  font-size: 0.84rem;
  color: #555;
  line-height: 1.7;
}

/* リンク段（SNS + 詳しく見る を一行に）*/
.profile-links {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 9px;
  margin-top: 9px;
  font-size: 0.8rem;
}

.profile-links a {
  color: #888;
  border-bottom: 1px dotted #a4aecb;
  padding-bottom: 1px;
  transition: color 0.2s, border-color 0.2s;
  white-space: nowrap;
}

.profile-links a:hover {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
}

/* SNS と「詳しく見る →」の間の縦区切り */
.profile-links__sep {
  display: inline-block;
  width: 1px;
  height: 11px;
  background: var(--c-border);
  vertical-align: middle;
  margin: 0 3px;   /* sep 前後だけ少し広く */
}

/* 「詳しく見る →」だけ少し強い色 */
.profile-more {
  color: var(--c-text-secondary) !important;
  border-bottom-color: transparent !important;
  letter-spacing: 0.02em;
}

.profile-more:hover {
  color: var(--c-accent) !important;
}


/* ================================================================
   [6] WORK — 作品個別ページ
        WP: page-work.php / page-{slug}.php
   ================================================================ */

.work-hero {
  line-height: 0;
  overflow: hidden;
  border-bottom: 1px solid #dce4f0;
}

.work-hero-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  max-height: 340px;
}

.work-face {
  margin-bottom: 36px;
}

.work-face-title {
  font-size: 1.4rem;
  font-weight: 500;
  color: #333;
  letter-spacing: 0.03em;
  margin-bottom: 6px;
}

.work-face-meta {
  font-size: 0.78rem;
  color: #999;
  margin-bottom: 20px;
}

.work-face-tagline {
  font-size: 1rem;
  color: #555;
  line-height: 1.8;
}

.work-synopsis {
  margin-bottom: 8px;
}

.work-synopsis p {
  font-size: 0.88rem;
  color: #444;
  line-height: 2.1;
  margin-bottom: 14px;
}

.work-synopsis p:last-child {
  margin-bottom: 0;
}

.work-divider {
  border: none;
  border-top: 1px solid #e0dbc8;
  margin: 36px 0;
}

/* 作品内セクション見出し（登場人物・あらすじ内などの小見出し）
 * WP化時: `.entry-content h3` に相当、スタイルは別途 */
.work-section-title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--c-text-strong);
  letter-spacing: 0.05em;
  margin-bottom: 14px;
  padding-left: 8px;
  border-left: 2px solid var(--c-accent);
}

.character-brief {
  font-size: 0.85rem;
}

.character-brief-item {
  display: flex;
  gap: 12px;
  padding: 6px 0;
}

.character-brief-item + .character-brief-item {
  border-top: 1px dotted #e0dbc8;
}

.character-brief-item dt {
  flex-shrink: 0;
  width: 11em;
  font-weight: 500;
  color: #444;
}

.character-brief-item dd {
  color: #666;
}

.work-read-note {
  font-size: 0.8rem;
  color: #888;
  margin-bottom: 10px;
}

.chapter-list {
  list-style: none;
  border: 1px solid #d8e0f0;
  margin-bottom: 24px;
}

.chapter-list li {
  border-bottom: 1px solid #dfe3ee;
}

.chapter-list li:last-child {
  border-bottom: none;
}

.chapter-list a {
  display: flex;
  padding: 10px 16px;
  font-size: 0.85rem;
  color: #444;
  transition: background 0.15s;
}

.chapter-list a:hover {
  background: rgba(var(--c-heading-band-rgb), 0.50);
  color: var(--c-accent-dark);
}

.chapter-list .ch-num {
  color: #999;
  font-size: 0.78rem;
  flex-shrink: 0;
  margin-right: 12px;
}

/* OFFLINE 系 legacy layer（旧: event-card / book-item）
   .event-card family は現行 offline テンプレでは未使用の旧 UI 層。
   削除はまだ行わず、legacy 候補として位置づける。 */
.event-card {
  border: 1px solid rgba(var(--c-accent-rgb), 0.18);
  background: rgba(var(--c-accent-rgb), 0.04);
  padding: 20px 24px;
  margin-bottom: 20px;
}

.event-card .event-name {
  font-weight: 500;
  font-size: 0.95rem;
  color: var(--c-text-strong);
  margin-bottom: 4px;
}

.event-card .event-detail {
  font-size: 0.85rem;
  color: var(--c-text-main);
  line-height: 1.85;
}

.event-card.is-next {
  border-left: 3px solid var(--c-accent);
}

.book-item {
  display: flex;
  gap: 20px;
  align-items: flex-start;
  padding: 16px 0;
}

.book-item + .book-item {
  border-top: 1px dotted #e0dbc8;
}

.book-cover {
  flex-shrink: 0;
  width: 120px;
  line-height: 0;
}

.book-cover img {
  width: 100%;
  border: 1px solid #cfd8ec;
}

.book-info {
  flex: 1;
}

.book-title {
  font-size: 0.92rem;
  font-weight: 500;
  color: #444;
  margin-bottom: 4px;
}

.book-meta {
  font-size: 0.78rem;
  color: #888;
  margin-bottom: 8px;
}

.book-desc {
  font-size: 0.84rem;
  color: #444;
  line-height: 1.85;
}


/* ================================================================
   [7] ARCHIVE — 投稿一覧（日記一覧）
        WP: archive.php
        対応クラス: .archive-body / .post-list / .post-card / .post-card__*
        ※ カテゴリ別一覧（category.php）は記事数が増えてから検討
   ================================================================ */

/* 投稿一覧ページラッパー
 * WP: archive.php の <main> 直下の外枠 div
 * .page-body との違い: > p に padding-left なし（entry-content が自前でスタイルを持つ） */
.archive-body {
  flex: 1;
  padding: 38px 48px 32px;
}

/* 投稿一覧の見出し帯
 * 左線テーマ色 + Pair Color 背景で、見出しとして成立させる */
.archive-body .chapter-title {
  max-width: 860px;
  margin-top: 0;
  margin-bottom: 24px;
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}

.archive-body .chapter-title span {
  color: var(--c-accent);
}

/* 一覧ラッパー
 * WP: <div class="post-list"> で while(have_posts()) ループを囲む
 * 各記事は <article class="post-card"> で出力（WP の標準的な article 要素）*/
.post-list {
  display: flex;
  flex-direction: column;
  max-width: 860px;
}

/* 投稿カード
 * WP: get_template_part('template-parts/content', 'diary') の出力単位
 * HTML: <article class="post-card"> — li ではなく article で意味を持たせる */
.post-card {
  padding: 22px 0;
  border-bottom: 1px dotted #e0dbc8;
}

.post-card:first-child {
  padding-top: 0;
}

.post-card:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

/* ヘッダー行：メタ（日付 + カテゴリ）→ タイトルの縦積み */
.post-card__head {
  margin-bottom: 8px;
}

/* メタ行：日付とカテゴリを1行に並べる（補助情報として小さく） */
.post-card__meta {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 2px;
}

/* 投稿日
 * WP: <time datetime="<?php echo get_the_date('Y-m-d') ?>"> */
.post-card__date {
  flex-shrink: 0;
  font-size: 0.75rem;
  color: #777;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
}

/* 投稿タイトルリンク
 * WP: <a href="<?php the_permalink() ?>"><?php the_title() ?></a>
 * meta（日付・カテゴリ）より明確に目立たせる */
.post-card__title {
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--c-text-strong);
  line-height: 1.45;
}

.post-card__title a {
  color: inherit;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s, color 0.15s;
}

.post-card__title a:hover {
  color: var(--c-accent);
  border-bottom-color: rgba(var(--c-accent-rgb), 0.35);
}

/* カテゴリ小ラベル
 * WP: get_the_category()[0]->name — .post-card__meta 内の flex 子要素
 * Pair Color #F2F0DF を背景に、テーマ色系の濃い青で文字 */
.post-card__cat {
  font-size: 0.68rem;
  color: var(--c-accent-dark);
  letter-spacing: 0.08em;
  background: rgba(var(--c-accent-rgb), 0.09);
  padding: 1px 7px 2px;
  border-radius: 2px;
}

/* 抜粋
 * WP: <?php the_excerpt() ?> → excerpt length は functions.php で調整 */
.post-card__excerpt {
  font-size: 0.85rem;
  color: #333;
  line-height: 1.9;
  margin-bottom: 10px;
}

/* 続きを読む
 * WP: <a href="<?php the_permalink() ?>">続きを読む</a> */
.post-card__more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  font-size: 0.78rem;
  color: var(--c-accent);
  letter-spacing: 0.04em;
  border: 1px solid rgba(var(--c-accent-rgb), 0.28);
  border-radius: 999px;
  background: rgba(var(--c-accent-rgb), 0.06);
  transition: color 0.15s, border-color 0.15s, background-color 0.15s, transform 0.15s;
}

.post-card__more:hover {
  color: var(--c-accent-dark);
  text-decoration: none;
  border-color: rgba(var(--c-accent-rgb), 0.42);
  background: rgba(var(--c-accent-rgb), 0.11);
  transform: translateY(-1px);
}

/* 日記一覧 補助ナビゲーション（最近の投稿 / カテゴリ / アーカイブ）
 * template-parts/diary-subnav.php で出力
 * pager の直後、site-footer の前に配置 */
.diary-subnav {
  display: flex;
  gap: 28px;
  margin-top: 40px;
  padding-top: 22px;
  border-top: 1px solid rgba(220, 224, 236, 0.5);
}

.diary-subnav__col {
  flex: 1;
  min-width: 0;
}

/* 補助ナビの小見出し — テーマ色左線 + Pair Color 背景で見出しとして明確化 */
.diary-subnav__head {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--c-text-strong);
  letter-spacing: 0.06em;
  margin: 0 0 10px;
  padding: 4px 10px;
  border-left: 3px solid var(--c-accent);
  border-bottom: none;
  background: rgba(var(--c-heading-band-rgb), 0.18);
}

/* 共通リストリセット（wp_list_categories / wp_get_archives の出力も含む）*/
.diary-subnav__list,
.diary-subnav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.diary-subnav__item,
.diary-subnav li {
  padding: 3px 0;
  font-size: 0.78rem;
  line-height: 1.5;
}

.diary-subnav__list a,
.diary-subnav li a {
  color: var(--c-accent);
  text-decoration: none;
  transition: color 0.12s;
}

.diary-subnav__list a:hover,
.diary-subnav li a:hover {
  color: var(--c-accent-dark);
  text-decoration: underline;
}

/* 最近の投稿の日付（タイトル下に小さく — 補助情報は #777 系 ）*/
.diary-subnav__date {
  display: block;
  font-size: 0.68rem;
  color: #777;
  margin-top: 1px;
  margin-bottom: 4px;
}

/* wp_list_categories が出すカウント数（補助情報）*/
.diary-subnav .post-count {
  font-size: 0.68rem;
  color: #777;
  margin-left: 3px;
}

/* モバイルで縦積み */
@media (max-width: 560px) {
  .diary-subnav {
    flex-direction: column;
    gap: 20px;
  }
}


/* ================================================================
   [8] SINGLE — 投稿個別ページ（日記）
        WP: single.php
        対応クラス: .single-body / .entry-header / .entry-content / .entry-nav
   ================================================================ */

/* 投稿個別ページラッパー
 * WP: single.php の <main> 直下の外枠 div
 * .page-body との違い: > p に padding-left なし（entry-content が自前でスタイルを持つ） */
.single-body {
  flex: 1;
  padding: 38px 48px 32px;
}

.single-body .chapter-title {
  margin-top: 0;
}

/* 一覧へ戻るリンク */
.post-back {
  max-width: 752px;
  margin-top: 28px;
  font-size: 0.80rem;
}

.post-back a {
  color: #888;
}

.post-back a:hover {
  color: var(--c-accent);
}

/* 投稿ヘッダー全体
 * WP: single.php の <?php while(have_posts()) ?> 内先頭部 */
/* entry-header — カレンダー型2カラムレイアウト
 * 左: .entry-date-block（日 + 年月を縦積み）
 * 右: .entry-header__body（タイトル + カテゴリ） */
.entry-header {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  max-width: 752px;
  margin-bottom: 28px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(var(--c-accent-rgb), 0.18);
}

/* 日付ブロック（<time> 要素）
 * WP: <time class="entry-date-block" datetime="..."> */
.entry-date-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  width: 52px;
  padding-top: 2px;
  text-decoration: none;
}

/* 日（数字）— 最も目立つ要素 */
.entry-day {
  display: block;
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--c-accent);
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}

/* 年月 — 日の直下、小さく */
.entry-month {
  display: block;
  font-size: 0.64rem;
  color: var(--c-accent);
  letter-spacing: 0.06em;
  margin-top: 3px;
  font-variant-numeric: tabular-nums;
}

/* タイトル＋カテゴリを束ねるラッパー */
.entry-header__body {
  flex: 1;
  min-width: 0;
}

/* 投稿タイトル（h1）
 * WP: <h1 class="entry-title"><?php the_title() ?></h1> */
.entry-title {
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--c-text-strong);
  letter-spacing: 0.02em;
  line-height: 1.55;
  margin-bottom: 8px;
}

/* カテゴリ（オプション）
 * WP: <span class="entry-cat"><?php echo esc_html($cat->name) ?></span> */
.entry-cat {
  display: inline-block;
  font-size: 0.70rem;
  color: var(--c-spot);
  letter-spacing: 0.08em;
  background: rgba(var(--c-spot-rgb), 0.12);
  padding: 1px 8px 2px;
  border-radius: 2px;
  vertical-align: middle;
}

/* 投稿本文ラッパー
 * WP: <div class="entry-content"><?php the_content() ?></div>
 * NOTE: .page-body p とは独立。padding-left を付けないことで
 *       WP が出力するブロック要素との干渉を防ぐ */
.entry-content {
  max-width: 752px;
}

.entry-content p {
  font-size: 0.88rem;
  color: #444;
  line-height: 2.05;
  margin-bottom: 14px;
}

.entry-content p:last-child {
  margin-bottom: 0;
}

/* 本文内見出し h2
 * WP: ブロックエディタの「見出し」ブロック（H2）がここに当たる
 * NOTE: .chapter-title（固定ページ用）とは独立した定義。
 *       .entry-content 内のみにスコープを限定しているため
 *       固定ページ・トップページの h2 には影響しない */
.entry-content h2 {
  font-size: 1.0rem;
  font-weight: 600;
  color: var(--c-text-strong);
  margin: 28px 0 10px;
  padding: 4px 14px 6px 12px;
  border-left: 3px solid var(--c-accent);
  border-bottom: 1px solid rgba(var(--c-accent-rgb), 0.12);
  background-color: rgba(var(--c-heading-band-rgb), 0.18);
}

/* 本文内小見出し h3 */
.entry-content h3 {
  font-size: 0.90rem;
  font-weight: 600;
  color: var(--c-text-strong);
  margin: 20px 0 8px;
  padding-left: 8px;
  border-left: 2px solid var(--c-accent);
}

/* リスト（ul / ol）
 * WP: ブロックエディタの「リスト」ブロック */
.entry-content ul,
.entry-content ol {
  margin: 0 0 14px 1.4em;
  font-size: 0.88rem;
  color: #444;
  line-height: 2.0;
}

.entry-content li + li {
  margin-top: 1px;
}

/* 引用（blockquote）
 * WP: ブロックエディタの「引用」ブロック */
.entry-content blockquote {
  margin: 16px 0;
  padding: 10px 18px;
  border-left: 3px solid rgba(var(--c-accent-rgb), 0.35);
  background: rgba(var(--c-heading-band-rgb), 0.18);
  font-size: 0.86rem;
  color: #555;
  line-height: 1.95;
}

.entry-content blockquote p {
  margin-bottom: 0;
}

/* 画像・figure
 * WP: ブロックエディタの「画像」ブロック → <figure class="wp-block-image"> として出力 */
.entry-content figure {
  margin: 16px 0;
}

.entry-content img {
  max-width: 100%;
  height: auto;
  display: block;
}

.entry-content figcaption {
  font-size: 0.76rem;
  color: #999;
  margin-top: 5px;
  text-align: center;
}

/* ━━ Gutenberg / ブロックエディタ由来クラスとの干渉対策メモ ━━━━━━━━━━━━
 * WP が出力する .wp-block-* クラスについて:
 *
 * .wp-block-paragraph  → 通常の <p> と同一。追加 margin なし
 * .wp-block-image      → <figure class="wp-block-image"> を含む
 *                         → 上記 figure / img スタイルで共存可
 * .wp-block-quote      → <blockquote> ベース。上記 blockquote スタイルで共存可
 * .wp-block-heading    → <h2> / <h3> を含む。.entry-content h2/h3 が自動適用される
 *
 * 注意: グローバルスコープの h2 / h3 装飾（例: .chapter-title への依存）は
 *       .entry-content 外に出さないこと。
 *       WP テーマ実装時は theme.json で editor-style を設定し、
 *       エディタプレビューと front-end の表示を一致させること。
 * ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Gutenberg ブロッククラス最低限スタイル
 * 上記の .entry-content ルールと協調し、崩れを防ぐ最小セット */
.entry-content .wp-block-image {
  margin-top: 0;
  margin-bottom: 16px;
}

.entry-content .wp-block-quote {
  padding: 10px 18px;
}

.entry-content .wp-block-list {
  padding-left: 1.4em;
}

/* 前後記事ナビゲーション
 * WP: the_post_navigation() または custom next/prev_post_link() */
.entry-nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  max-width: 752px;
  padding-top: 24px;
  margin-top: 28px;
  border-top: 1px solid rgba(var(--c-accent-rgb), 0.15);
  font-size: 0.80rem;
}

.entry-nav__prev,
.entry-nav__next {
  color: #888;
  max-width: 48%;
}

.entry-nav__prev a,
.entry-nav__next a {
  color: var(--c-accent);
}

.entry-nav__prev a:hover,
.entry-nav__next a:hover {
  color: #3d5fa0;
}

.entry-nav__next {
  text-align: right;
  margin-left: auto;
}


/* ================================================================
   [9] MEMO — 短い断片・記録ページ
        WP: page-memo.php（固定ページで運用）
        diary との差異:
          diary = 読む記事（タイトル主体・段落あり・続きを読む）
          memo  = 短い記録（日付主体・コンパクト・全文表示）
   ================================================================ */

/* メモページ本文ラッパー */
.memo-body {
  flex: 1;
  padding: 38px 48px 40px;
}

/* 各メモ項目
 * 左にアイボリー帯を置き、「書きとめた断片」感を出す
 * diary の post-card より compact で全文表示 */
.memo-item {
  padding: 10px 14px;
  border-left: 3px solid rgba(var(--c-heading-band-rgb), 1.0);   /* Pair Color 帯 */
  background: rgba(var(--c-heading-band-rgb), 0.25);
  margin-bottom: 14px;
  border-radius: 0 2px 2px 0;
}

.memo-item:last-child {
  margin-bottom: 0;
}

/* 日付（タイトルの上に小さく）*/
.memo-date {
  font-size: 0.71rem;
  color: #b0a898;
  letter-spacing: 0.04em;
  font-variant-numeric: tabular-nums;
  margin-bottom: 2px;
}

/* キャプション的タイトル（diary ほど主張しない）*/
.memo-title {
  font-size: 0.84rem;
  font-weight: 600;
  color: #3a3530;
  margin-bottom: 5px;
}

/* 本文（全文。短いことが前提）*/
.memo-text {
  font-size: 0.83rem;
  color: #555;
  line-height: 1.85;
}


/* ================================================================
   [10] UTIL — ハンバーガー / オーバーレイ / 汎用
   ================================================================ */

.menu-toggle {
  display: none;
  position: fixed;
  top: 14px;
  right: 14px;
  z-index: 1100;
  width: 44px;
  height: 44px;
  padding: 10px 9px;
  border: 1px solid #b8c5dc;
  border-radius: 4px;
  background: rgba(255,255,255,0.92);
  cursor: pointer;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  -webkit-tap-highlight-color: transparent;
}

.menu-toggle-bar {
  display: block;
  width: 100%;
  height: 2px;
  background: #555;
  border-radius: 1px;
  transition: transform 0.25s, opacity 0.2s;
}

[aria-expanded="true"] .menu-toggle-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

[aria-expanded="true"] .menu-toggle-bar:nth-child(2) {
  opacity: 0;
}

[aria-expanded="true"] .menu-toggle-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.menu-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 999;
  background: rgba(0,0,0,0.35);
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}

body.menu-open {
  overflow: hidden;
}

/* ページャ（アーカイブ前後・ページネーション）*/
.pager {
  display: flex;
  justify-content: space-between;
  max-width: 860px;
  font-size: 0.82rem;
  padding-top: 8px;
}

.pager a {
  color: #888;
  border-bottom: 1px dotted #a4aecb;
}

.pager a:hover {
  color: #3d5fa0;
}


/* ================================================================
   [11] RESPONSIVE
   ================================================================ */

@media (max-width: 900px) {

  .menu-toggle {
    display: flex;
  }

  .menu-overlay {
    display: block;
  }

  .site {
    flex-direction: column;
  }

  .kanban {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1000;
    width: min(82vw, 320px);
    height: 100vh;
    height: 100dvh;
    border-right: 1px solid #b8c5dc;
    overflow-y: auto;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
  }

  .kanban-visual {
    display: none;
  }

  .mobile-site-hero {
    display: block;
    width: 100%;
    background: var(--c-card-bg);
    border-bottom: 1px solid var(--c-border);
    overflow: hidden;
  }

  .mobile-site-hero img,
  .mobile-site-hero--placeholder {
    width: 100%;
    height: clamp(180px, 48vw, 260px);
    object-fit: cover;
    object-position: center top;
  }

  .mobile-site-hero--placeholder {
    background-color: #ffffff;
    background-image: url("assets/image/menu-hero-pattern.svg");
    background-position: center top;
    background-repeat: repeat;
    background-size: 160px 160px;
  }

  .kanban-name {
    padding: 18px 20px 14px;
  }

  body.menu-open .kanban {
    transform: translateX(0);
  }

  body.menu-open .menu-overlay {
    opacity: 1;
    pointer-events: auto;
  }

  .kanban[aria-hidden="true"]  { visibility: hidden; }
  .kanban[aria-hidden="false"] { visibility: visible; }

  .kanban-nav {
    padding: 6px 0 0;
  }

  .kanban-nav a {
    padding: 12px 18px;
    font-size: 0.9rem;
    letter-spacing: 0.03em;
  }

  .kanban-nav a::before {
    display: none;
  }

  .kanban-note {
    padding: 14px 20px 18px;
    text-align: left;
  }

  .kanban-external {
    padding: 18px 20px 12px;
    margin-top: auto;
  }
  
  .kanban-external__list {
    gap: 16px;
  }

  .kanban-nav .menu-item-has-children > a::after {
    margin-left: 12px;
  }

  .kanban-nav .sub-menu {
    padding: 2px 0 8px;
  }

  .kanban-nav .sub-menu > li > a {
    min-height: auto;
    padding: 10px 18px 10px 32px;
    font-size: 0.81rem;
    letter-spacing: 0.02em;
    color: var(--c-text-secondary);
    background-color: transparent;
  }

  .kanban-nav .sub-menu > li > a::before {
    display: none;
  }

  /* 作品個別 */
  .work-hero-img {
    max-height: 200px;
  }

  .character-brief-item {
    flex-direction: column;
    gap: 2px;
  }

  .character-brief-item dt {
    width: auto;
  }

  .book-item {
    flex-direction: column;
  }

  .book-cover {
    width: 100px;
  }

}

@media (max-width: 560px) {

  .top-upper__side {
    padding: 0 20px 22px;
  }

  .section-greeting,
  .section-update,
  .section-work,
  .section-event,
  .section-profile,
  .site-footer,
  .page-body,
  .archive-body,
  .single-body,
  .memo-body {
    padding-left: 20px;
    padding-right: 20px;
  }

  .chapter-title {
    font-size: 0.97rem;
  }

  .profile-card {
    padding: 14px 16px 12px;
  }

  .profile-body {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .profile-icon {
    padding-right: 0;
  }

  .profile-text {
    width: 100%;
    padding-left: 0;
    text-align: center;
  }

  .profile-text::before {
    display: none;
  }

  .profile-links {
    justify-content: center;
  }

  /* アーカイブ */
  .post-list {
    padding: 0 20px;
  }

  /* 単一記事 */
  .entry-nav {
    flex-direction: column;
    gap: 10px;
  }

  .entry-nav__next {
    text-align: left;
    margin-left: 0;
  }

  /* メモ */
  .memo-item {
    padding: 8px 12px;
  }
}

/* ================================================================
   [12] WP ADJUSTMENTS — child theme integration
   ================================================================ */

body {
  min-height: 100vh;
}

.kanban-name a,
.kanban-name a:hover {
  color: inherit;
}

.kanban-name a {
  display: inline-block;
  max-width: 100%;
}

.kanban-name__logo {
  display: block;
  width: min(100%, 228px);
  height: auto;
  margin: 0 auto;
}

.content {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
}

body.blog .content,
body.archive .content,
body.single-post .content,
body.page-template-page-diary .content {
  min-height: auto;
}

.content > .section-greeting,
.content > .section-update,
.content > .top-upper,
.content > .section-work,
.content > .section-event,
.content > .section-profile,
.content > .page-body,
.content > .archive-body,
.content > .single-body,
.content > .memo-body,
.content > .site-footer {
  width: 100%;
}

body.blog .content > .archive-body + .site-footer,
body.archive .content > .archive-body + .site-footer,
body.single-post .content > .single-body + .site-footer,
body.page-template-page-diary .content > .archive-body + .site-footer {
  margin-top: 0;
  padding-top: 12px;
  padding-bottom: 18px;
  border-top-color: rgba(220, 224, 236, 0.35);
  background: none;
}

/* トップへ戻る — 通常リンクとして視認できるテーマ色 */
body.blog .content > .archive-body + .site-footer a,
body.archive .content > .archive-body + .site-footer a,
body.page-template-page-diary .content > .archive-body + .site-footer a {
  color: var(--c-accent);
  border-bottom: none;
}

body.blog .content > .archive-body + .site-footer a:hover,
body.archive .content > .archive-body + .site-footer a:hover,
body.page-template-page-diary .content > .archive-body + .site-footer a:hover {
  color: var(--c-accent-dark);
  text-decoration: underline;
}

.page-body > h2,
.memo-body > h2 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--c-text-strong);
  margin-bottom: 24px;
  padding: 6px 16px 6px 10px;
  border-left: 3px solid var(--c-accent);
  border-radius: 2px;
  background: rgba(232, 226, 212, 0.72);
}

.page-body > h2::before,
.memo-body > h2::before {
  content: '';
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--c-accent);
}

.page-body > h3,
.memo-body > h3 {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--c-text-strong);
  margin-bottom: 24px;
  padding: 5px 16px 8px 14px;
  border-left: 4px solid var(--c-accent);
  border-bottom: 1px solid rgba(var(--c-accent-rgb), 0.15);
  background-color: rgba(var(--c-heading-band-rgb), 0.18);
}

.page-body > h2:first-child,
.memo-body > h2:first-child,
.page-body > h3:first-child,
.memo-body > h3:first-child {
  margin-top: 0;
}

.page-body > h2:not(:first-child),
.memo-body > h2:not(:first-child),
.page-body > h3:not(:first-child),
.memo-body > h3:not(:first-child) {
  margin-top: 48px;
}

.page-body > ul,
.page-body > ol,
.memo-body > ul,
.memo-body > ol {
  margin: 0 0 14px 2.4em;
  color: #444;
  font-size: 0.84rem;
  line-height: 1.9;
}

.page-body > figure,
.memo-body > figure {
  margin: 18px 0 18px 16px;
}

.page-body > .wp-block-image,
.memo-body > .wp-block-image {
  margin-left: 16px;
  margin-right: 0;
}

.page-body > blockquote,
.page-body > .wp-block-quote {
  margin: 18px 0 18px 16px;
  padding: 10px 14px 11px 16px;
  border-left: 3px solid rgba(var(--c-accent-rgb), 0.38);
  background: rgba(var(--c-heading-band-rgb), 0.18);
  color: #4a4a4a;
}

.page-body > blockquote p,
.page-body > .wp-block-quote p {
  margin: 0;
  padding-left: 0;
  font-size: 0.85rem;
  line-height: 1.95;
}

.page-body > figure img,
.page-body > .wp-block-image img {
  border: 1px solid #dce0ec;
}

.page-body > figure figcaption,
.page-body > .wp-block-image figcaption {
  margin-top: 6px;
  font-size: 0.74rem;
  line-height: 1.7;
  color: #8a8f98;
}

.about-body > .wp-block-media-text {
  margin: 18px 0 18px 16px;
  align-items: center;
  column-gap: 20px;
}

.about-body > .wp-block-media-text .wp-block-media-text__media img {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid #dce0ec;
}

.about-body > .wp-block-media-text .wp-block-media-text__content {
  padding: 0;
}

.about-body > .wp-block-media-text .wp-block-media-text__content p {
  font-size: 0.85rem;
  color: #444;
  line-height: 1.9;
  margin-bottom: 6px;
}

.post-card__excerpt {
  white-space: pre-line;
}

/*
 * NOTE:
 * この付近は公開後に積み上げたトーン調整レイヤー。
 * style.css は現状、ベース構造と後段の色味・質感調整が混線しているため、
 * 大きな整理は見た目改修と切り分けてまとめて行う。
 */
.log-scroll {
  padding: 10px 16px 11px;
  border-color: rgba(var(--c-accent-rgb), 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

.log-entry {
  gap: 16px;
  padding: 6px 0;
}

.log-date {
  width: 6.95em;
}

.log-text {
  line-height: 1.75;
}

.log-text a {
  color: inherit;
}

.log-text a:hover {
  color: #3d5fa0;
}

.work-banner__placeholder {
  width: 100%;
  height: 100%;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0) 42%),
    linear-gradient(160deg, #8bb1d0 0%, #6d8fb4 55%, #50667a 100%);
}

.profile-icon__placeholder {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(160deg, #8ea9cc 0%, #637fbd 100%);
  color: #f7f9fb;
  display: grid;
  place-items: center;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.entry-cat a,
.entry-cat a:hover {
  color: inherit;
}

.entry-content .wp-block-heading {
  margin-bottom: 0;
}

.entry-content .wp-block-list {
  margin-left: 0;
}

.entry-content .wp-block-image img {
  display: block;
}

.entry-content .wp-block-image figcaption {
  margin-top: 5px;
}

.entry-nav__prev:empty,
.entry-nav__next:empty {
  display: none;
}

.kanban-visual__placeholder {
  width: 100%;
  height: 100%;
  background:
    radial-gradient(circle at 28% 18%, rgba(255,255,255,0.92), rgba(255,255,255,0) 18%),
    radial-gradient(circle at 62% 24%, rgba(255,255,255,0.8), rgba(255,255,255,0) 19%),
    radial-gradient(circle at 74% 34%, rgba(255,255,255,0.55), rgba(255,255,255,0) 16%),
    linear-gradient(180deg, #8fb2d6 0%, #6d8db8 56%, #dbe4f1 100%);
}

.kanban {
  background: var(--c-sidebar-bg);
  box-shadow: inset -1px 0 0 var(--c-border);
}

.kanban-visual {
  border-bottom: 1px solid var(--c-border);
}

.kanban-name {
  padding: 18px 22px 18px;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.7;
  letter-spacing: 0.08em;
  border-bottom: 0;
  background: transparent;
}

.kanban-nav {
  border-top: 0;
}

.kanban-nav a {
  min-height: 46px;
  padding: 12px 20px;
  font-size: 0.84rem;
  color: var(--c-text-main);
  border-bottom-color: rgba(0, 0, 0, 0.10);
}

.kanban-nav a:hover,
.kanban-nav a:focus-visible {
  color: var(--c-accent-dark);
  background: rgba(var(--c-accent-rgb), 0.07);
}

.kanban-nav a[aria-current="page"] {
  color: var(--c-text-strong);
  background: rgba(var(--c-accent-rgb), 0.09);
  box-shadow: inset 3px 0 0 var(--c-accent);
}

.kanban-note {
  padding: 18px 0 20px;
  font-size: 0.69rem;
  letter-spacing: 0.04em;
}

.site-footer {
  margin-top: auto;
}

@media (max-width: 900px) {
  .content > .section-greeting,
  .content > .section-update,
  .content > .top-upper,
  .content > .section-work,
  .content > .section-event,
  .content > .section-profile,
  .content > .page-body,
  .content > .archive-body,
  .content > .single-body,
  .content > .memo-body,
  .content > .site-footer {
    width: 100%;
  }
}

body.admin-bar .menu-toggle {
  top: 46px;
}

body.admin-bar .kanban {
  top: 32px;
  height: calc(100vh - 32px);
  height: calc(100dvh - 32px);
}

@media (max-width: 782px) {
  body.admin-bar .menu-toggle {
    top: 60px;
  }

  body.admin-bar .kanban {
    top: 46px;
    height: calc(100vh - 46px);
    height: calc(100dvh - 46px);
  }
}

/* WordPress menu support for kanban */
.kanban-nav ul,
.kanban-nav li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.kanban-nav__list {
  display: flex;
  flex-direction: column;
  padding: 0 0 8px;
}

.kanban-nav li {
  display: block;
  width: 100%;
  box-sizing: border-box;
}

.kanban-nav li > a {
  display: flex;
  align-items: center;
  width: 100%;
  box-sizing: border-box;
}

.kanban-nav .menu-item-has-children > a::after {
  content: '';
  width: 6px;
  height: 6px;
  margin-left: auto;
  border-right: 1.5px solid var(--c-accent);
  border-bottom: 1.5px solid var(--c-accent);
  transform: rotate(45deg);
  opacity: 0.75;
}

.kanban-nav .sub-menu {
  margin: 0;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
}

.kanban-nav .sub-menu > li {
  width: 100%;
  box-sizing: border-box;
}

.kanban-nav .sub-menu > li > a {
  min-height: 46px;
  padding: 12px 20px;
  width: 100%;
  box-sizing: border-box;
  font-size: 0.77rem;
  letter-spacing: 0.04em;
  color: var(--c-text-secondary);
  background-color: rgba(var(--c-accent-rgb), 0.04);
}

.kanban-nav .sub-menu > li > a::before {
  width: 8px;
  height: 8px;
  margin-left: 18px;
  margin-right: 10px;
}

.kanban-nav .current-menu-item > a,
.kanban-nav .current-menu-ancestor > a,
.kanban-nav .current-menu-parent > a,
.kanban-nav .current_page_item > a,
.kanban-nav .current_page_ancestor > a {
  color: var(--c-text-strong);
  font-weight: 600;
  background-color: rgba(var(--c-accent-rgb), 0.09);
  box-shadow: inset 3px 0 0 var(--c-accent);
}

.kanban-nav .current-menu-item > a::before,
.kanban-nav .current-menu-ancestor > a::before,
.kanban-nav .current-menu-parent > a::before,
.kanban-nav .current_page_item > a::before,
.kanban-nav .current_page_ancestor > a::before {
  opacity: 1;
  transform: translateX(0);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 0.5 L7.1 4.9 L11.5 6 L7.1 7.1 L6 11.5 L4.9 7.1 L0.5 6 L4.9 4.9 Z' fill='%233F67B1'/%3E%3C/svg%3E");
  transition: none;
}

@media (max-width: 1050px) {
  .top-upper {
    display: flex;
    flex-direction: column;
  }

  .top-upper__main {
    display: contents;
  }

  .section-greeting {
    order: 1;
  }

  .top-upper__side {
    order: 2;
    padding: 0 48px 24px;
  }

  .section-memo-brief {
    max-width: 320px;
  }

  .section-update {
    order: 3;
  }

  /* 作品バナー + 説明を縦積み */
  .work-link {
    flex-direction: column;
  }

  .work-banner {
    width: 100%;
    max-width: 480px;
  }
}

@media (max-width: 900px) {
  .kanban-nav .sub-menu > li > a::before {
    margin-left: 24px;
  }
}

@media (max-width: 560px) {
  .top-upper__side {
    padding: 0 20px 22px;
  }

  .section-memo-brief {
    max-width: 100%;
  }

  .work-banner {
    max-width: 100%;
  }
}

/* ================================================================
   [13] HONKAN COLOR TUNE — quiet warmth
   ================================================================ */

body {
  color: var(--c-text-main);
  background: var(--c-page-bg);
}

a {
  color: var(--c-accent);
}

a:hover {
  color: var(--c-accent-dark);
}

html,
body {
  background: var(--c-page-bg) !important;
}

.site {
  background: var(--c-content-bg);
  box-shadow: 1px 0 0 rgba(63, 103, 177, 0.18), -1px 0 0 rgba(63, 103, 177, 0.18);
}

.content {
  background: var(--c-content-bg);
}

.content > .section-greeting,
.content > .section-update,
.content > .top-upper,
.content > .section-work,
.content > .section-event,
  .content > .section-profile,
.content > .page-body,
.content > .archive-body,
.content > .single-body,
.content > .memo-body,
.content > .site-footer {
  background: var(--c-card-bg);
}

.kanban {
  background: var(--c-sidebar-bg);
  border-right-color: var(--c-border);
  box-shadow: inset -1px 0 0 rgba(var(--c-border-rgb), 0.42);
}

.kanban-visual,
.work-hero,
.work-banner,
.book-cover img,
.page-body > figure img,
.page-body > .wp-block-image img,
.about-body > .wp-block-media-text .wp-block-media-text__media img,
.chapter-list,
.event-card,
.log-scroll {
  border-color: var(--c-border);
}

.kanban-visual__placeholder {
  background-color: #ffffff;
  background-image: url("assets/image/menu-hero-pattern.svg");
  background-position: center top;
  background-repeat: repeat;
  background-size: 160px 160px;
}

.work-banner__placeholder {
  width: 100%;
  height: 100%;
  background: #d6dde4;
}

.profile-card {
  background: var(--c-surface-soft);
  border-color: var(--c-border);
}

.profile-text {
  border-left-color: rgba(var(--c-accent-rgb), 0.28);
}

.profile-icon__placeholder {
  background: var(--c-accent);
  color: var(--c-card-bg);
}

.profile-links a {
  border-bottom-color: rgba(var(--c-accent-rgb), 0.35);
}

.profile-links__sep {
  background: var(--c-border);
}

.kanban-name {
  color: var(--c-text-strong);
  border-bottom-color: rgba(var(--c-border-rgb), 0.80);
  background: transparent;
}

.kanban-nav {
  border-top: 0;
}

.kanban-nav a {
  color: var(--c-text-main);
  border-bottom-color: rgba(var(--c-border-rgb), 0.74);
}

.kanban-nav a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 0.5 L7.1 4.9 L11.5 6 L7.1 7.1 L6 11.5 L4.9 7.1 L0.5 6 L4.9 4.9 Z' fill='none' stroke='%233F67B1' stroke-width='1.0'/%3E%3C/svg%3E");
}

.kanban-nav a:hover,
.kanban-nav a:focus-visible {
  color: var(--c-accent-dark);
  background: rgba(var(--c-accent-rgb), 0.07);
}

.kanban-nav a[aria-current="page"],
.kanban-nav .current-menu-item > a,
.kanban-nav .current-menu-ancestor > a,
.kanban-nav .current-menu-parent > a,
.kanban-nav .current_page_item > a,
.kanban-nav .current_page_ancestor > a {
  color: var(--c-text-strong);
  background: rgba(var(--c-accent-rgb), 0.09);
  box-shadow: inset 3px 0 0 var(--c-accent);
}

.kanban-nav a[aria-current="page"]::before,
.kanban-nav .current-menu-item > a::before,
.kanban-nav .current-menu-ancestor > a::before,
.kanban-nav .current-menu-parent > a::before,
.kanban-nav .current_page_item > a::before,
.kanban-nav .current_page_ancestor > a::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 0.5 L7.1 4.9 L11.5 6 L7.1 7.1 L6 11.5 L4.9 7.1 L0.5 6 L4.9 4.9 Z' fill='%233F67B1'/%3E%3C/svg%3E");
}

.kanban-nav .menu-item-has-children > a::after {
  border-right-color: var(--c-accent);
  border-bottom-color: var(--c-accent);
}

.kanban-nav .sub-menu > li > a {
  color: var(--c-text-secondary);
  background-color: rgba(var(--c-accent-rgb), 0.04);
}

.kanban-external {
  border-top: 0;
}

.kanban-external__link {
  background: transparent;
}

.kanban-external__link:not(.is-placeholder):hover,
.kanban-external__link:not(.is-placeholder):focus-visible {
  opacity: 0.72;
}

/* NOTE:
   この後段トーン調整レイヤーは現役 class だけでなく legacy event class にも触っている。
   旧 .event-* family の削除判断は、この層の参照整理を先に確認してから行うこと。 */
.kanban-note,
.site-footer,
body.blog .content > .archive-body + .site-footer,
body.archive .content > .archive-body + .site-footer,
body.single-post .content > .single-body + .site-footer,
body.page-template-page-diary .content > .archive-body + .site-footer,
.page-note,
.work-lead,
.event-status-note,
.work-face-meta,
.memo-date,
.post-card__date,
.diary-subnav__date,
.diary-subnav .post-count,
.book-meta,
.log-date,
.cen-past-item,
.post-back a,
.entry-nav__prev,
.entry-nav__next,
.page-body > figure figcaption,
.page-body > .wp-block-image figcaption,
.entry-content figcaption {
  color: var(--c-text-secondary);
}

.site-footer,
body.blog .content > .archive-body + .site-footer,
body.archive .content > .archive-body + .site-footer,
body.single-post .content > .single-body + .site-footer,
body.page-template-page-diary .content > .archive-body + .site-footer {
  border-top-color: rgba(var(--c-border-rgb), 0.5);
  background: var(--c-card-bg);
}

.chapter-title,
.archive-body .chapter-title,
.page-body > h2,
.page-body > h3,
.memo-body > h2,
.memo-body > h3 {
  font-family: "Zen Maru Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
  color: var(--c-text-strong);
  border-left-color: var(--c-accent);
  background: rgba(232, 226, 212, 0.72);
}

.section-event .cen-card--featured .cen-card__name,
.ob-event-bar-name {
  font-family: "Zen Maru Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;
}

.archive-body .chapter-title span {
  color: var(--c-accent);
}

.page-body > p,
.page-body > section > p,
.section-greeting p,
.log-text,
.work-desc,
.event-name,
.event-detail,
.profile-name,
.profile-text p,
.work-face-title,
.work-face-tagline,
.work-synopsis p,
.character-brief-item dt,
.character-brief-item dd,
.book-title,
.book-desc,
.post-card__title,
.post-card__excerpt,
.entry-title,
.entry-content p,
.entry-content ul,
.entry-content ol,
.entry-content blockquote,
.memo-title,
.memo-text,
.about-body > .wp-block-media-text .wp-block-media-text__content p {
  color: var(--c-text-main);
}

.work-title,
.entry-title,
.post-card__title,
.work-section-title,
.entry-content h2,
.entry-content h3 {
  color: var(--c-text-strong);
}

.work-link:hover .work-title,
.post-card__title a:hover,
.post-card__more:hover,
.diary-subnav__list a:hover,
.diary-subnav li a:hover,
.log-text a:hover,
.post-back a:hover,
.entry-nav__prev a:hover,
.entry-nav__next a:hover,
.pager a:hover,
.profile-links a:hover {
  color: var(--c-accent-dark);
}

.work-more a:hover,
.work-more a:focus-visible {
  color: #fbfaf7;
}

.work-more a,
.post-card__more,
.diary-subnav__list a,
.diary-subnav li a,
body.blog .content > .archive-body + .site-footer a,
body.archive .content > .archive-body + .site-footer a,
body.page-template-page-diary .content > .archive-body + .site-footer a,
.entry-nav__prev a,
.entry-nav__next a {
  color: var(--c-accent);
}

.link-list a,
.profile-links a,
.pager a {
  border-bottom-color: rgba(var(--c-accent-rgb), 0.45);
}

.section-update .log-scroll {
  background: rgba(63,103,177,0.04);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

.memo-brief-more a {
  border-bottom-color: rgba(var(--c-accent-rgb), 0.32);
}

.log-scroll::-webkit-scrollbar-track {
  background: #f3eee6;
}

.log-scroll::-webkit-scrollbar-thumb {
  background: #d1c9be;
}

.work-banner {
  box-shadow: 0 2px 14px rgba(76, 86, 95, 0.08);
}

.work-divider,
.cen-past-list,
.book-item + .book-item,
.log-entry + .log-entry,
.chapter-list li,
.post-card,
.entry-header,
.entry-nav,
.diary-subnav {
  border-color: rgba(var(--c-border-rgb), 0.68);
}

.chapter-list a {
  color: var(--c-text-main);
}

.chapter-list a:hover {
  background: rgba(var(--c-heading-band-rgb), 0.72);
  color: var(--c-accent-dark);
}

.event-card {
  background: var(--c-card-bg);
}

.event-card.is-next,
.work-section-title,
.entry-content h2,
.entry-content h3 {
  border-left-color: var(--c-accent-dark);
}

.post-card__cat,
.entry-cat {
  color: var(--c-accent-dark);
  background: rgba(var(--c-accent-rgb), 0.09);
}

.entry-day {
  color: var(--c-accent);
}

.entry-month {
  color: var(--c-accent);
}

.entry-content blockquote,
.page-body > blockquote,
.page-body > .wp-block-quote,
.memo-item {
  color: var(--c-text-main);
  border-left-color: rgba(var(--c-accent-rgb), 0.30);
  background: rgba(var(--c-heading-band-rgb), 0.28);
}

.menu-toggle {
  border-color: rgba(var(--c-border-rgb), 0.92);
  background: rgba(247, 244, 241, 0.95);
}

.menu-toggle-bar {
  background: var(--c-text-main);
}
