/*
Theme Name: シンプルSEOブログ
Theme URI: https://example.com/simple-seo-blog
Author: SEO職業訓練
Author URI: https://example.com/
Description: SEO職業訓練の受講者が「記事投稿だけに集中」できる、超シンプルなブログ特化クラシックテーマ。白基調・本文max-width720px・装飾最小。Article/BreadcrumbList の JSON-LD と最小OGPフォールバックのみ内蔵し、title/詳細SEOは SEO SIMPLE PACK 等のプラグインへ委譲します。外部サーバ通信は一切ありません。
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
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;

  /* タイポグラフィ: 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. アクセシビリティ補助
   ========================================================= */
.sseo-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 {
  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-border);
  background: var(--sseo-color-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-text); text-decoration: none; }
.sseo-site-description {
  margin: .2em 0 0;
  color: var(--sseo-color-muted);
  font-size: .9rem;
}

.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;
}

/* 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-border);
  border-radius: var(--sseo-radius);
  padding: .5em .9em;
  font: inherit;
  color: var(--sseo-color-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-text);
  padding: .3em 0;
}
.sseo-nav__menu a:hover { color: var(--sseo-color-accent); }
.sseo-nav__menu .current-menu-item > a { color: var(--sseo-color-accent); font-weight: 700; }

@media (max-width: 767px) {
  .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; }

.sseo-post__thumbnail { margin-bottom: 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; }

/* 動きを減らす指定への配慮 */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}
