/*
Theme Name: シンプルSEOブログ
Theme URI: https://example.com/simple-seo-blog
Author: SEO職業訓練
Author URI: https://example.com/
Description: SEO職業訓練の受講者が「記事の執筆と公開に集中」しながら、手順に沿うだけで見栄えの整ったブログを作れるシンプルなブログ特化クラシックテーマ。デザインプリセット（着せ替え）を1つ選ぶだけで、色だけでなくカードの形・影・見出し装飾・余白まで含めたスタイル（ナチュラル／マガジン／ミニマル／クラシック）に切り替わります。トップページのバナー（ヒーロー）・カード型一覧（カテゴリラベル付き）・目次の自動生成・プロフィール（著者）ウィジェット・関連記事を内蔵。色／ヘッダー色／フォント／本文サイズ／一覧レイアウト／バナーもカスタマイザで個別設定できます。Article/BreadcrumbList の JSON-LD と最小OGPフォールバックを内蔵し、title/詳細SEOは SEO SIMPLE PACK 等のプラグインへ委譲。外部サーバ通信・Webフォント読込は一切ありません。
Version: 1.5.4
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: simple-seo-blog
Tags: blog, one-column, two-columns, custom-menu, featured-images, threaded-comments, translation-ready, accessibility-ready
*/

/* =========================================================
   1. CSS カスタムプロパティ（集中管理）
   ========================================================= */
:root {
  /* 色: モノトーン + アクセント1色（濃紺） */
  --sseo-color-bg: #ffffff;
  --sseo-color-text: #1a1a1a;
  --sseo-color-muted: #5a5a5a;
  --sseo-color-border: #e5e5e5;
  --sseo-color-surface: #f7f7f7;
  --sseo-color-accent: #1f3a5f;
  --sseo-color-accent-dark: #16293f;
  --sseo-color-link: #1f3a5f;

  /* ヘッダーの帯（カスタマイザで背景色を変更可。既定は白＋通常の文字色）。
     暗い背景色を選んだときは customizer が文字色を白系へ上書きする。 */
  --sseo-color-header-bg: var(--sseo-color-bg);
  --sseo-color-header-text: var(--sseo-color-text);
  --sseo-color-header-muted: var(--sseo-color-muted);
  --sseo-color-header-border: var(--sseo-color-border);

  /* タイポグラフィ: Noto Sans JP を指定（外部読込なし／system fontへfallback） */
  --sseo-font-base: "Noto Sans JP", -apple-system, BlinkMacSystemFont,
    "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo",
    system-ui, sans-serif;
  --sseo-font-size: 1rem;        /* 16px 基準 */
  --sseo-line-height: 1.85;

  /* レイアウト */
  --sseo-content-width: 720px;
  --sseo-wide-width: 1080px;
  --sseo-sidebar-width: 280px;

  /* 余白（広め） */
  --sseo-space-xs: 0.5rem;
  --sseo-space-sm: 1rem;
  --sseo-space-md: 1.75rem;
  --sseo-space-lg: 3rem;
  --sseo-space-xl: 4.5rem;

  --sseo-radius: 6px;
}

/* =========================================================
   2. リセット / ベース
   ========================================================= */
*,
*::before,
*::after { box-sizing: border-box; }

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

body {
  margin: 0;
  background: var(--sseo-color-bg);
  color: var(--sseo-color-text);
  font-family: var(--sseo-font-base);
  font-size: var(--sseo-font-size);
  line-height: var(--sseo-line-height);
  font-feature-settings: "palt";
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  /* 長いURL・連続した英数字/カタカナでも必ず折り返し、横スクロールを防ぐ */
  overflow-wrap: anywhere;
  word-break: normal;
}

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

a { color: var(--sseo-color-link); text-underline-offset: 2px; }
a:hover { color: var(--sseo-color-accent-dark); }

/* フォーカス可視化（a11y） */
:focus-visible {
  outline: 3px solid var(--sseo-color-accent);
  outline-offset: 2px;
}

h1, h2, h3, h4, h5, h6 {
  line-height: 1.4;
  font-weight: 700;
  margin: 1.6em 0 0.6em;
  word-break: keep-all;       /* 日本語の不自然な改行を抑制 */
  overflow-wrap: anywhere;    /* 折り返し不能な長語（長いURL等）は強制改行してはみ出しを防ぐ */
}
h1 { font-size: 1.9rem; }
h2 { font-size: 1.5rem; border-bottom: 2px solid var(--sseo-color-border); padding-bottom: .3em; }
h3 { font-size: 1.25rem; }
h4 { font-size: 1.1rem; }

p { margin: 0 0 1.4em; }
ul, ol { padding-left: 1.4em; }

blockquote {
  margin: 1.6em 0;
  padding: .8em 1.2em;
  border-left: 4px solid var(--sseo-color-accent);
  background: var(--sseo-color-surface);
  color: var(--sseo-color-muted);
}

code, pre {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}
pre {
  background: var(--sseo-color-surface);
  padding: 1em;
  overflow-x: auto;
  border-radius: var(--sseo-radius);
}
code { background: var(--sseo-color-surface); padding: .15em .4em; border-radius: 4px; }

table { border-collapse: collapse; width: 100%; margin: 1.4em 0; }
th, td { border: 1px solid var(--sseo-color-border); padding: .6em .8em; text-align: left; }
th { background: var(--sseo-color-surface); }

hr { border: 0; border-top: 1px solid var(--sseo-color-border); margin: var(--sseo-space-lg) 0; }

/* =========================================================
   3. アクセシビリティ補助
   ========================================================= */
/* 接頭辞付き(テーマ自前) と、WordPress コアが出力する素の .screen-reader-text の両方を
   視覚的に隠す。コア関数（the_post_navigation / the_comments_navigation /
   wp_list_comments / comment-reply 等）が固定で出す screen-reader-text への対応として必須。 */
.sseo-screen-reader-text,
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px; width: 1px;
  margin: -1px; padding: 0;
  overflow: hidden;
  position: absolute !important;
  word-wrap: normal !important;
}
.sseo-screen-reader-text:focus,
.screen-reader-text:focus {
  background: var(--sseo-color-bg);
  clip: auto; clip-path: none;
  color: var(--sseo-color-accent);
  display: block;
  height: auto; width: auto;
  padding: .8em 1em;
  position: static !important;
  z-index: 100000;
}

.sseo-skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 100000;
  background: var(--sseo-color-accent);
  color: #fff;
  padding: .8em 1.2em;
  border-radius: 0 0 var(--sseo-radius) 0;
  text-decoration: none;
}
.sseo-skip-link:focus {
  left: 0;
  color: #fff;
}

/* =========================================================
   4. レイアウト
   ========================================================= */
.sseo-site-header {
  border-bottom: 1px solid var(--sseo-color-header-border);
  background: var(--sseo-color-header-bg);
}
.sseo-site-header__inner {
  max-width: var(--sseo-wide-width);
  margin: 0 auto;
  padding: var(--sseo-space-md) var(--sseo-space-sm);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sseo-space-sm);
}
.sseo-site-branding { min-width: 0; }
.sseo-site-title {
  margin: 0;
  font-size: 1.4rem;
  font-weight: 800;
}
.sseo-site-title a { color: var(--sseo-color-header-text); text-decoration: none; }
.sseo-site-description {
  margin: .2em 0 0;
  color: var(--sseo-color-header-muted);
  font-size: .9rem;
}
/* FV（トップバナー）でキャッチフレーズを大きく出すページでは、
   ヘッダー側のキャッチフレーズは重複するので隠す（FVが無いページでは従来どおり表示）。 */
.sseo-fv-on .sseo-site-description { display: none; }

.sseo-main { display: block; }

.sseo-layout {
  max-width: var(--sseo-wide-width);
  margin: 0 auto;
  padding: var(--sseo-space-lg) var(--sseo-space-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sseo-space-lg);
}

.sseo-content {
  width: 100%;
  max-width: var(--sseo-content-width);
  margin: 0 auto;
  min-width: 0;
}

.sseo-sidebar {
  width: 100%;
  max-width: var(--sseo-content-width);
  margin: 0 auto;
  min-width: 0; /* flex 子要素が縮めるように（横並び時のはみ出し防止） */
}

/* テキスト要素の折り返し安全網: 長いURL・連続英数字でも横にはみ出さない。
   見た目は通常と同じで、折り返せない語だけ強制改行する（デスクトップも同挙動）。 */
.sseo-content,
.sseo-post__title,
.sseo-post__excerpt,
.sseo-post__content,
.sseo-breadcrumb,
.sseo-entry-meta,
.sseo-post__meta,
.sseo-post__footer,
.sseo-archive-description,
.sseo-widget,
.comment-body {
  overflow-wrap: anywhere;
  min-width: 0;
}

.sseo-site-footer {
  border-top: 1px solid var(--sseo-color-border);
  background: var(--sseo-color-surface);
  margin-top: var(--sseo-space-xl);
}
.sseo-site-footer__inner {
  max-width: var(--sseo-wide-width);
  margin: 0 auto;
  padding: var(--sseo-space-md) var(--sseo-space-sm);
  color: var(--sseo-color-muted);
  font-size: .9rem;
  text-align: center;
}

/* フッタの SNS リンク（装飾最小） */
.sseo-site-footer__sns { margin-bottom: var(--sseo-space-sm); }
.sseo-sns-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--sseo-space-sm);
}
.sseo-sns-list__link {
  color: var(--sseo-color-link);
  text-decoration: none;
}
.sseo-sns-list__link:hover { color: var(--sseo-color-accent-dark); }

/* カスタムロゴ（ヘッダ）: 高さを抑え、長辺で崩れないように。
   推奨＝透過PNG・横長 約480×120px（表示は高さ約48px）。 */
.sseo-site-title .custom-logo {
  height: auto;
  max-height: 48px;
  width: auto;
}

/* 2カラム（任意の細いサイドバー）: 広い画面のみ横並び */
@media (min-width: 960px) {
  .sseo-layout--has-sidebar {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    max-width: var(--sseo-wide-width);
  }
  .sseo-layout--has-sidebar .sseo-content { margin: 0; }
  .sseo-layout--has-sidebar .sseo-sidebar {
    width: var(--sseo-sidebar-width);
    flex: 0 0 var(--sseo-sidebar-width);
    margin: 0;
    position: sticky;
    top: var(--sseo-space-sm);
  }
}

/* =========================================================
   5. ナビゲーション
   ========================================================= */
.sseo-nav { position: relative; }
.sseo-nav__toggle {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  background: none;
  border: 1px solid var(--sseo-color-header-border);
  border-radius: var(--sseo-radius);
  padding: .5em .9em;
  font: inherit;
  color: var(--sseo-color-header-text);
  cursor: pointer;
}
.sseo-nav__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sseo-space-sm);
}
.sseo-nav__menu a {
  text-decoration: none;
  color: var(--sseo-color-header-text);
  padding: .3em 0;
}
/* hover/現在地は背景色に依存しないよう不透明度＋太字で示す（ヘッダー背景を変えても読める）。 */
.sseo-nav__menu a:hover { color: var(--sseo-color-header-text); opacity: .7; }
.sseo-nav__menu .current-menu-item > a { color: var(--sseo-color-header-text); font-weight: 700; }

/* 子メニュー（階層メニュー）: ドロップダウンにはせず、親の下に静的なサブリストとして
   インデント表示する（JS不要・初学者が階層メニューを作っても崩れない）。 */
.sseo-nav__menu .sub-menu {
  list-style: none;
  margin: .3em 0 0;
  padding-left: .9em;
  border-left: 2px solid var(--sseo-color-border);
}
.sseo-nav__menu .sub-menu a { font-size: .92em; }

@media (max-width: 767px) {
  /* ナビ自体をヘッダー行いっぱいに折り返して全幅にする。
     これが無いと開いたメニューが最長項目幅に潰れて右に寄る。 */
  .sseo-nav { flex: 1 0 100%; }
  .sseo-nav__toggle { display: inline-flex; }
  .sseo-nav__menu {
    display: none;
    flex-direction: column;
    width: 100%;
    margin-top: var(--sseo-space-sm);
    gap: var(--sseo-space-xs);
  }
  .sseo-nav--open .sseo-nav__menu { display: flex; }
}
@media (min-width: 768px) {
  .sseo-nav__toggle { display: none; }
  .sseo-nav__menu { display: flex !important; }
}

/* =========================================================
   6. 記事・一覧
   ========================================================= */
.sseo-page-title {
  font-size: 1.6rem;
  margin: 0 0 var(--sseo-space-md);
}

.sseo-post {
  padding-bottom: var(--sseo-space-lg);
  margin-bottom: var(--sseo-space-lg);
  border-bottom: 1px solid var(--sseo-color-border);
}
.sseo-post:last-child { border-bottom: 0; }
/* 単一記事/固定ページの本文記事は一覧用の区切り線・下余白を持たない
   （後続に前後ナビ・関連記事・コメントが続くため :last-child に当たらない）。 */
.sseo-article.sseo-post { border-bottom: 0; padding-bottom: 0; margin-bottom: 0; }

/* figure の UA 既定マージン（左右40px）を打ち消す。single/page の主役画像が
   本文より内側に寄って崩れるのを防ぐ（一覧カード/リストは別途 margin:0 で上書き）。 */
.sseo-post__thumbnail { margin: 0 0 var(--sseo-space-sm); }
.sseo-post__thumbnail img { border-radius: var(--sseo-radius); width: 100%; }

.sseo-post__title { margin: 0 0 var(--sseo-space-xs); font-size: 1.4rem; }
.sseo-post__title a { color: var(--sseo-color-text); text-decoration: none; }
.sseo-post__title a:hover { color: var(--sseo-color-accent); }

.sseo-article .sseo-post__title { font-size: 1.9rem; }

.sseo-post__meta,
.sseo-byline,
.sseo-entry-meta {
  color: var(--sseo-color-muted);
  font-size: .85rem;
  display: flex;
  flex-wrap: wrap;
  gap: .25em 1em;
  margin-bottom: var(--sseo-space-sm);
}
.sseo-posted-on,
.sseo-updated-on,
.sseo-posted-by { white-space: nowrap; }
.sseo-updated-on { font-weight: 700; color: var(--sseo-color-accent); }

.sseo-post__excerpt { margin-bottom: var(--sseo-space-sm); }
.sseo-post__content { margin-top: var(--sseo-space-md); }

.sseo-post__footer {
  margin-top: var(--sseo-space-md);
  font-size: .85rem;
  color: var(--sseo-color-muted);
}

/* =========================================================
   7. パンくず
   ========================================================= */
.sseo-breadcrumb {
  font-size: .82rem;
  color: var(--sseo-color-muted);
  margin-bottom: var(--sseo-space-md);
}
.sseo-breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: .25em .5em;
}
.sseo-breadcrumb__item { display: inline-flex; align-items: center; gap: .5em; }
.sseo-breadcrumb__item:not(:last-child)::after {
  content: "/";
  color: var(--sseo-color-border);
}
.sseo-breadcrumb__item a { text-decoration: none; }
.sseo-breadcrumb__current { color: var(--sseo-color-text); }

/* =========================================================
   8. ページネーション
   ========================================================= */
.sseo-pagination { margin-top: var(--sseo-space-lg); }
.sseo-pagination .nav-links,
.sseo-pagination__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sseo-space-xs);
  justify-content: center;
  align-items: center;
}
.sseo-pagination .page-numbers {
  display: inline-flex;
  min-width: 2.4em;
  height: 2.4em;
  align-items: center;
  justify-content: center;
  padding: 0 .6em;
  border: 1px solid var(--sseo-color-border);
  border-radius: var(--sseo-radius);
  text-decoration: none;
  color: var(--sseo-color-text);
}
.sseo-pagination .page-numbers.current {
  background: var(--sseo-color-accent);
  border-color: var(--sseo-color-accent);
  color: #fff;
}
.sseo-pagination a.page-numbers:hover {
  border-color: var(--sseo-color-accent);
  color: var(--sseo-color-accent);
}

/* =========================================================
   9. ウィジェット / ボタン / フォーム
   ========================================================= */
.sseo-widget {
  margin-bottom: var(--sseo-space-lg);
  font-size: .92rem;
}
.sseo-widget__title {
  font-size: 1rem;
  margin: 0 0 var(--sseo-space-sm);
  padding-bottom: .3em;
  border-bottom: 2px solid var(--sseo-color-accent);
}
.sseo-widget ul { list-style: none; padding: 0; margin: 0; }
.sseo-widget li { padding: .35em 0; border-bottom: 1px solid var(--sseo-color-border); }

.sseo-button {
  display: inline-block;
  background: var(--sseo-color-accent);
  color: #fff;
  text-decoration: none;
  padding: .6em 1.2em;
  border-radius: var(--sseo-radius);
  border: 0;
  font: inherit;
  cursor: pointer;
}
.sseo-button:hover { background: var(--sseo-color-accent-dark); color: #fff; }

input[type="text"],
input[type="search"],
input[type="email"],
input[type="url"],
textarea {
  width: 100%;
  max-width: 100%;
  padding: .6em .8em;
  border: 1px solid var(--sseo-color-border);
  border-radius: var(--sseo-radius);
  font: inherit;
  background: var(--sseo-color-bg);
  color: var(--sseo-color-text);
}

/* =========================================================
   10. コメント（WP標準を最小整形）
   ========================================================= */
.comment-list { list-style: none; padding: 0; margin: 0; }
.comment-list .children { list-style: none; padding-left: var(--sseo-space-md); }
.comment-body {
  padding: var(--sseo-space-sm) 0;
  border-bottom: 1px solid var(--sseo-color-border);
}

/* =========================================================
   11. WordPress 標準クラス（最小限のサポート）
   ========================================================= */
.alignleft  { float: left; margin: 0 var(--sseo-space-md) var(--sseo-space-sm) 0; }
.alignright { float: right; margin: 0 0 var(--sseo-space-sm) var(--sseo-space-md); }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.wp-caption-text, .gallery-caption { font-size: .82rem; color: var(--sseo-color-muted); }
.sticky, .bypostauthor { display: block; }

.wp-block-image figcaption { font-size: .82rem; color: var(--sseo-color-muted); text-align: center; }

/* =========================================================
   12. 記事一覧のレイアウト（カード / リスト）
   ========================================================= */
/* カード型（既定）: アイキャッチを大きく見せるグリッド */
.sseo-post-list--card {
  display: grid;
  /* min() で「260px か 横幅100% の小さい方」を下限にし、狭い画面でカードが
     コンテナ幅を超えて横スクロールが出るのを防ぐ。 */
  grid-template-columns: repeat(auto-fill, minmax(min(260px, 100%), 1fr));
  gap: var(--sseo-space-md);
}
.sseo-post-list--card .sseo-post {
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: 0;
  border: 1px solid var(--sseo-color-border);
  border-radius: var(--sseo-radius);
  overflow: hidden;
  background: var(--sseo-color-bg);
  transition: box-shadow .15s ease;
}
.sseo-post-list--card .sseo-post:hover {
  box-shadow: 0 6px 20px rgba(0, 0, 0, .08);
}
.sseo-post-list--card .sseo-post__thumbnail { margin: 0; }
.sseo-post-list--card .sseo-post__thumbnail img,
.sseo-post-list--card .sseo-thumb-placeholder {
  width: 100%;
  border-radius: 0;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.sseo-post-list--card .sseo-post__body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  padding: var(--sseo-space-md);
  min-width: 0;
}
.sseo-post-list--card .sseo-post__title { font-size: 1.15rem; }
.sseo-post-list--card .sseo-post__excerpt { font-size: .9rem; }
.sseo-post-list--card .sseo-post__footer {
  margin-top: auto;
  padding-top: var(--sseo-space-sm);
}
.sseo-post-list--card .sseo-post__readmore { align-self: flex-start; }

/* リスト型: アイキャッチを左、本文を右に置く省スペース表示 */
.sseo-post-list--list { display: flex; flex-direction: column; }
.sseo-post-list--list .sseo-post {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--sseo-space-md);
  align-items: start;
}
.sseo-post-list--list .sseo-post__thumbnail { margin: 0; }
.sseo-post-list--list .sseo-post__thumbnail img,
.sseo-post-list--list .sseo-thumb-placeholder {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
.sseo-post-list--list .sseo-post__body { min-width: 0; }
.sseo-post-list--list .sseo-post__title { font-size: 1.2rem; }
@media (max-width: 600px) {
  .sseo-post-list--list .sseo-post { grid-template-columns: 1fr; }
}

/* アイキャッチ未設定時のプレースホルダ（外部画像なし・インラインSVG） */
.sseo-post__thumbnail--placeholder a { display: block; }
.sseo-thumb-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: linear-gradient(135deg, var(--sseo-color-surface), #eef1f5);
  color: var(--sseo-color-muted);
}
.sseo-thumb-placeholder__icon { opacity: .7; }

/* =========================================================
   13. 記事本文の見出し（上品な既定装飾）
   ========================================================= */
.sseo-post__content h2 {
  border-bottom: 1px solid var(--sseo-color-border);
  border-left: 5px solid var(--sseo-color-accent);
  padding: .25em .7em .4em;
}
.sseo-post__content h3 {
  border-left: 4px solid var(--sseo-color-border);
  padding-left: .6em;
}
/* 目次アンカーでジャンプしたとき、見出しが画面上端に貼り付かないように */
.sseo-post__content h2[id],
.sseo-post__content h3[id] { scroll-margin-top: 1rem; }

/* =========================================================
   14. プロフィール（著者ボックス）ウィジェット
   ========================================================= */
.sseo-profile { text-align: center; }
.sseo-profile__avatar { margin: 0 0 var(--sseo-space-sm); }
.sseo-profile__img {
  width: 96px;
  height: 96px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto;
  display: block;
}
.sseo-profile__name {
  font-weight: 700;
  font-size: 1.05rem;
  margin: 0 0 var(--sseo-space-xs);
}
.sseo-profile__bio {
  text-align: left;
  font-size: .9rem;
  color: var(--sseo-color-muted);
  margin: 0 0 var(--sseo-space-sm);
}
.sseo-profile__bio p:last-child { margin-bottom: 0; }
.sseo-profile__sns { margin-top: var(--sseo-space-sm); }
.sseo-profile__sns .sseo-sns-list { gap: var(--sseo-space-xs) var(--sseo-space-sm); }
.sseo-profile__sns .sseo-sns-list__link { font-size: .85rem; }

/* =========================================================
   15. 関連記事
   ========================================================= */
.sseo-related { margin-top: var(--sseo-space-xl); }
.sseo-related__title {
  font-size: 1.3rem;
  margin: 0 0 var(--sseo-space-md);
  padding-bottom: .3em;
  border-bottom: 2px solid var(--sseo-color-accent);
}
.sseo-related__item .sseo-post__title { font-size: 1rem; }

/* =========================================================
   16. 目次（本文から自動生成）
   ========================================================= */
.sseo-toc {
  background: var(--sseo-color-surface);
  border: 1px solid var(--sseo-color-border);
  border-radius: var(--sseo-radius);
  padding: var(--sseo-space-md);
  margin: 0 0 var(--sseo-space-lg);
}
.sseo-toc__title {
  font-weight: 700;
  margin: 0 0 var(--sseo-space-xs);
}
.sseo-toc__list {
  margin: 0;
  padding-left: 1.4em;
}
.sseo-toc__item { margin: .3em 0; }
.sseo-toc__item--h3 {
  margin-left: 1.2em;
  font-size: .92em;
  list-style: circle;
}
.sseo-toc a { text-decoration: none; }
.sseo-toc a:hover { text-decoration: underline; }

/* =========================================================
   17. Contact Form 7（導入時だけ効く・未導入でも無害）
   ========================================================= */
.wpcf7-form p { margin: 0 0 var(--sseo-space-sm); }
.wpcf7-form label { display: block; font-weight: 600; margin-bottom: .3em; }
.wpcf7-form input[type="tel"],
.wpcf7-form select { width: 100%; }
.wpcf7-form .wpcf7-submit {
  display: inline-block;
  background: var(--sseo-color-accent);
  color: #fff;
  border: 0;
  border-radius: var(--sseo-radius);
  padding: .7em 1.6em;
  font: inherit;
  cursor: pointer;
}
.wpcf7-form .wpcf7-submit:hover { background: var(--sseo-color-accent-dark); }
.wpcf7-spinner { margin: 0 .5em; }
.wpcf7-not-valid-tip { color: #b3261e; font-size: .85rem; margin-top: .2em; }
.wpcf7-response-output {
  border-radius: var(--sseo-radius);
  margin: var(--sseo-space-sm) 0 0 !important;
  padding: .8em 1em;
}

/* =========================================================
   18. トップページのバナー（ヒーロー）
   ========================================================= */
.sseo-hero {
  position: relative;
  margin: 0 0 var(--sseo-space-lg);
  background: var(--sseo-color-surface);
  overflow: hidden;
}
.sseo-hero__media { line-height: 0; }
.sseo-hero__img {
  width: 100%;
  height: 100%;
  max-height: 440px;
  object-fit: cover;
  display: block;
}

/* 画像に文字を重ねるとき: 読みやすくする暗幕＋中央寄せ */
.sseo-hero--has-text .sseo-hero__inner {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sseo-space-lg) var(--sseo-space-md);
  background: linear-gradient(rgba(0, 0, 0, .30), rgba(0, 0, 0, .45));
}
.sseo-hero__box {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  color: #fff;
  overflow-wrap: anywhere;
}
.sseo-hero__title,
.sseo-hero__text { overflow-wrap: anywhere; }
.sseo-hero__title {
  font-size: clamp(1.5rem, 4.2vw, 2.5rem);
  font-weight: 800;
  line-height: 1.3;
  margin: 0 0 .4em;
  text-shadow: 0 2px 14px rgba(0, 0, 0, .5);
}
.sseo-hero__text {
  font-size: clamp(1rem, 2.4vw, 1.15rem);
  line-height: 1.7;
  margin: 0 0 1.1em;
  text-shadow: 0 1px 10px rgba(0, 0, 0, .5);
}
.sseo-hero__button { font-weight: 700; }

/* 画像なし（テキストだけ）のバナー: アクセント色のグラデーション帯にする（画像が無くても“映える”FV） */
.sseo-hero--noimage { background: linear-gradient(135deg, var(--sseo-color-accent), var(--sseo-color-accent-dark)); }
.sseo-hero--noimage .sseo-hero__inner {
  position: static;
  background: none;
  padding: var(--sseo-space-xl) var(--sseo-space-md);
}
.sseo-hero--noimage .sseo-hero__title,
.sseo-hero--noimage .sseo-hero__text { text-shadow: none; }
/* キャッチフレーズの見出しはわずかな字間だけ（装飾の区切り線は入れない＝すっきり） */
.sseo-hero--noimage .sseo-hero__title { letter-spacing: .02em; }
.sseo-hero--noimage .sseo-hero__button { background: #fff; color: var(--sseo-color-accent); }
.sseo-hero--noimage .sseo-hero__button:hover { background: var(--sseo-color-surface); color: var(--sseo-color-accent-dark); }

@media (max-width: 600px) {
  .sseo-hero__img { max-height: 300px; }
}

/* =========================================================
   19. カテゴリーラベル（カードの主カテゴリ表示）
   ========================================================= */
.sseo-post__cat {
  display: inline-block;
  align-self: flex-start;
  margin: 0 0 .55em;
  padding: .2em .8em;
  font-size: .72rem;
  font-weight: 700;
  line-height: 1.6;
  border-radius: 999px;
  background: var(--sseo-color-surface);
  color: var(--sseo-color-accent);
  text-decoration: none;
}
.sseo-post__cat:hover { color: var(--sseo-color-accent-dark); }

/* =========================================================
   20. デザインプリセットのスタイル（着せ替え）
   body.sseo-style-<key> で、色だけでなく構造の見た目を切り替える。
   ========================================================= */

/* --- ナチュラル: 丸い影付きカード・やわらかい・カテゴリは淡色チップ --- */
.sseo-style-natural .sseo-post-list--card { gap: var(--sseo-space-lg); }
.sseo-style-natural .sseo-post-list--card .sseo-post {
  border: 0;
  border-radius: 16px;
  box-shadow: 0 6px 22px rgba(0, 0, 0, .07);
  transition: transform .18s ease, box-shadow .18s ease;
}
.sseo-style-natural .sseo-post-list--card .sseo-post:hover {
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(0, 0, 0, .12);
}
.sseo-style-natural .sseo-post__cat {
  background: color-mix(in srgb, var(--sseo-color-accent) 12%, #fff);
}
.sseo-style-natural .sseo-button { border-radius: 999px; }
.sseo-style-natural .sseo-post__content h2 {
  border-bottom: 0;
  border-left: 6px solid var(--sseo-color-accent);
  border-radius: 2px;
  padding: .15em .8em;
}
.sseo-style-natural .sseo-post__content h3 { border-left-width: 4px; }

/* --- マガジン: 直線・枠線・影なし・カテゴリはベタ塗りラベル・見出しは下線 --- */
.sseo-style-magazine .sseo-post-list--card { gap: var(--sseo-space-md); }
.sseo-style-magazine .sseo-post-list--card .sseo-post {
  border: 1px solid var(--sseo-color-border);
  border-radius: 0;
  box-shadow: none;
}
.sseo-style-magazine .sseo-post-list--card .sseo-post:hover { border-color: var(--sseo-color-accent); }
.sseo-style-magazine .sseo-post__cat {
  border-radius: 0;
  background: var(--sseo-color-accent);
  color: #fff;
  letter-spacing: .04em;
}
.sseo-style-magazine .sseo-button { border-radius: 0; }
.sseo-style-magazine .sseo-post__title { letter-spacing: .01em; }
.sseo-style-magazine .sseo-post__content h2 {
  border-left: 0;
  border-bottom: 3px solid var(--sseo-color-accent);
  padding: 0 0 .3em;
}
.sseo-style-magazine .sseo-post__content h3 {
  border-left: 0;
  border-bottom: 1px solid var(--sseo-color-border);
  padding: 0 0 .2em;
}

/* --- ミニマル: 枠も影もなし・余白広め・カテゴリは小さな文字・続きは矢印リンク --- */
.sseo-style-minimal .sseo-post-list--card { gap: var(--sseo-space-xl); }
.sseo-style-minimal .sseo-post-list--card .sseo-post {
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
}
.sseo-style-minimal .sseo-post-list--card .sseo-post__thumbnail img,
.sseo-style-minimal .sseo-post-list--card .sseo-thumb-placeholder { border-radius: 10px; }
.sseo-style-minimal .sseo-post-list--card .sseo-post__body { padding: var(--sseo-space-sm) 0 0; }
.sseo-style-minimal .sseo-post__cat {
  background: transparent;
  padding: 0;
  color: var(--sseo-color-muted);
  font-size: .72rem;
  letter-spacing: .1em;
}
.sseo-style-minimal .sseo-post__title { font-size: 1.3rem; }
.sseo-style-minimal .sseo-button {
  background: transparent;
  color: var(--sseo-color-accent);
  padding: .3em 0;
  border-radius: 0;
}
.sseo-style-minimal .sseo-button:hover { background: transparent; color: var(--sseo-color-accent-dark); text-decoration: underline; }
.sseo-style-minimal .sseo-post__readmore::after { content: " \2192"; }
.sseo-style-minimal .sseo-post__content h2 { border: 0; padding: 0; }
.sseo-style-minimal .sseo-post__content h2::before {
  content: "";
  display: block;
  width: 2.4em;
  border-top: 3px solid var(--sseo-color-accent);
  margin-bottom: .45em;
}
.sseo-style-minimal .sseo-post__content h3 { border: 0; padding: 0; }

/* --- クラシック: 明朝・細枠・上品な見出し・カテゴリは線囲み --- */
.sseo-style-classic .sseo-post-list--card .sseo-post {
  border: 1px solid var(--sseo-color-border);
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .04);
}
.sseo-style-classic .sseo-post__cat {
  background: transparent;
  border: 1px solid currentColor;
  border-radius: 2px;
  font-weight: 600;
}
.sseo-style-classic .sseo-button { border-radius: 2px; }
.sseo-style-classic .sseo-post__content h2 {
  border-left: 0;
  border-bottom: 2px solid var(--sseo-color-accent);
  padding: 0 0 .25em;
}
.sseo-style-classic .sseo-post__content h3 {
  border-left: 4px double var(--sseo-color-accent);
  padding-left: .55em;
}

/* =========================================================
   21. サイト名のロゴ風表示（ロゴ画像が無いとき＝body に wp-custom-logo が付かないとき）
   ロゴ画像をアップしなくても、サイト名テキストだけでデザインされた“ワードマーク”に見せる。
   ========================================================= */
body:not(.wp-custom-logo) .sseo-site-title {
  display: inline-flex;
  align-items: center;
  gap: .45em;
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -.01em;
  line-height: 1.12;
}
body:not(.wp-custom-logo) .sseo-site-title::before {
  content: "";
  flex: none;
  width: .44em;
  height: .44em;
  border-radius: 3px;
  background: var(--sseo-color-accent);
}

/* ナチュラル: アクセントの丸ドット＋やわらかい */
body.sseo-style-natural:not(.wp-custom-logo) .sseo-site-title::before { border-radius: 50%; }

/* マガジン: 白地のマストヘッド（暗いヘッダーに白box＋濃い文字でロゴらしく） */
body.sseo-style-magazine:not(.wp-custom-logo) .sseo-site-title { gap: 0; }
body.sseo-style-magazine:not(.wp-custom-logo) .sseo-site-title::before { display: none; }
body.sseo-style-magazine:not(.wp-custom-logo) .sseo-site-title a {
  background: #fff;
  color: #111827;
  padding: .12em .5em;
  letter-spacing: .02em;
}

/* ミニマル: 字間を広げた軽いワードマーク＋小さな四角 */
body.sseo-style-minimal:not(.wp-custom-logo) .sseo-site-title {
  font-weight: 700;
  font-size: 1.35rem;
  letter-spacing: .14em;
}
body.sseo-style-minimal:not(.wp-custom-logo) .sseo-site-title::before {
  width: .3em; height: .3em; border-radius: 0;
}

/* クラシック: 明朝＋アクセントの下線（上品なロゴタイプ） */
body.sseo-style-classic:not(.wp-custom-logo) .sseo-site-title::before { display: none; }
body.sseo-style-classic:not(.wp-custom-logo) .sseo-site-title a {
  border-bottom: 2px solid var(--sseo-color-accent);
  padding-bottom: .08em;
  letter-spacing: .04em;
}

/* 動きを減らす指定への配慮 */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .sseo-post-list--card .sseo-post,
  .sseo-style-natural .sseo-post-list--card .sseo-post { transition: none; }
  .sseo-style-natural .sseo-post-list--card .sseo-post:hover { transform: none; }
}
