/*
Theme Name: Cocoon Child
Template: cocoon-master
*/

/* ==============================================
   Kumagera Tech Blog — Redesign v2.0
   Design: Clean Editorial / Tech-Minimal
   
   変更点サマリー:
   - 可読性向上（本文16px、line-height 2.0）
   - 見出しの階層感を明確化
   - カテゴリ別カラーリング
   - CTAボタンの改善
   - 目次デザインの刷新
   - テーブルのゼブラストライプ化
   - no-image対策のプレースホルダー改善
   - カード一覧のメリハリ強化
   - フッターの情報整理
   - 全体的な余白・リズム調整
   ============================================== */

/* ===== CSS変数 ===== */
:root {
  /* カラーパレット */
  --text-main: #1a1a1a;
  --text-body: #333;
  --text-sub: #6b7280;
  --text-light: #9ca3af;
  --bg: #f8f9fb;
  --bg-subtle: #f1f3f6;
  --white: #fff;
  --accent: #2563eb;
  --accent-light: #dbeafe;
  --accent-dark: #1d4ed8;
  --accent-hover: #1e40af;
  --green: #059669;
  --green-light: #d1fae5;
  --orange: #d97706;
  --orange-light: #fef3c7;
  --purple: #7c3aed;
  --purple-light: #ede9fe;
  --red: #dc2626;
  --red-light: #fee2e2;
  --border: #e5e7eb;
  --border-light: #f0f1f3;

  /* レイアウト */
  --radius: 12px;
  --radius-sm: 8px;
  --radius-xs: 6px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.04);
  --shadow: 0 2px 8px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.06);
  --shadow-hover: 0 8px 30px rgba(0,0,0,0.10);

  /* トランジション */
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --duration: 0.2s;
}

/* ===== ベースリセット ===== */
body {
  background: var(--bg) !important;
  color: var(--text-body);
  font-family: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Hiragino Kaku Gothic ProN', sans-serif;
  font-size: 16px;
  line-height: 2.0;
  letter-spacing: 0.02em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  word-break: break-word;
  overflow-wrap: break-word;
}

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

a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--duration) var(--ease);
}
a:hover {
  color: var(--accent-hover);
}

/* テキスト選択時のハイライト色 */
::selection {
  background: var(--accent-light);
  color: var(--text-main);
}

/* ===== ヘッダー ===== */
.header, #header, .site-header-container {
  background: var(--white) !important;
  box-shadow: 0 1px 0 var(--border) !important;
  position: relative;
  z-index: 100;
}

.header-container-in {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

.logo-text, .site-name-text, .header .logo a {
  color: var(--text-main) !important;
  font-weight: 800 !important;
  font-size: 1.35em !important;
  letter-spacing: -0.03em;
}

/* グローバルナビ */
.navi, .global-menu, .navi-in {
  background: var(--white) !important;
  border-bottom: 1px solid var(--border-light);
}

.navi a, .global-menu a {
  color: var(--text-body) !important;
  font-size: 0.85em !important;
  font-weight: 600;
  padding: 12px 16px !important;
  position: relative;
  transition: color var(--duration) var(--ease);
}

.navi a:hover,
.global-menu a:hover {
  color: var(--accent) !important;
}

/* ナビホバー時にアンダーライン */
.navi a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 80%;
  height: 2px;
  background: var(--accent);
  transition: transform var(--duration) var(--ease);
}
.navi a:hover::after {
  transform: translateX(-50%) scaleX(1);
}

/* ===== レイアウト ===== */
.wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 28px 20px;
}

.main, #main, .main-body, #content, #body, .body {
  background: transparent !important;
}

/* ===== 記事一覧（カード型） ===== */
.entry-card-wrap {
  margin-bottom: 24px;
}

.entry-card {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--border-light) !important;
  box-shadow: var(--shadow-sm) !important;
  overflow: hidden;
  transition: transform var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease),
              border-color var(--duration) var(--ease);
}

.entry-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover) !important;
  border-color: var(--accent-light) !important;
}

.entry-card-thumb {
  position: relative;
  overflow: hidden;
}

.entry-card-thumb img {
  border-radius: 0 !important;
  transition: transform 0.4s var(--ease);
}

.entry-card:hover .entry-card-thumb img {
  transform: scale(1.03);
}

.entry-card-title {
  font-weight: 700 !important;
  font-size: 1.05em !important;
  color: var(--text-main) !important;
  line-height: 1.55;
  letter-spacing: -0.01em;
}

.entry-card-snippet {
  color: var(--text-sub) !important;
  font-size: 0.85em !important;
  line-height: 1.65;
}

.entry-card-content {
  padding: 16px 20px !important;
}

/* ===== カテゴリラベル（カテゴリ別カラー） ===== */
.cat-label, .category-label {
  font-size: 0.68em !important;
  font-weight: 700;
  padding: 3px 10px !important;
  border-radius: var(--radius-xs) !important;
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-transform: uppercase;
}

/* デフォルト（青） */
.cat-label, .category-label {
  background: var(--accent) !important;
  color: var(--white) !important;
}

/* カテゴリ別カラー — Cocoonのカテゴリごとにクラスが付く場合用 */
/* AI活用 → 青 */
.cat-label.cat-ai,
.cat-label[data-cat="ai"] {
  background: var(--accent) !important;
}

/* DX入門 → 緑 */
.cat-label.cat-dx,
.cat-label[data-cat="dx"] {
  background: var(--green) !important;
}

/* レンタルサーバー → オレンジ */
.cat-label.cat-server,
.cat-label[data-cat="server"] {
  background: var(--orange) !important;
}

/* ブログ運営 → 紫 */
.cat-label.cat-blog,
.cat-label[data-cat="blog"] {
  background: var(--purple) !important;
}

/* 副業・稼ぎ方 → 赤 */
.cat-label.cat-side,
.cat-label[data-cat="side"] {
  background: var(--red) !important;
}

/* 日付 */
.post-date, .entry-date, .post-update {
  color: var(--text-light) !important;
  font-size: 0.8em !important;
  font-weight: 500;
}

/* ===== 記事ページ ===== */
.article, .content {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  padding: 48px 44px !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid var(--border-light) !important;
}

/* 記事タイトル */
.entry-title {
  font-size: 1.75em !important;
  font-weight: 800 !important;
  line-height: 1.45 !important;
  color: var(--text-main) !important;
  margin-bottom: 20px !important;
  letter-spacing: -0.03em;
}

/* ===== 見出しデザイン ===== */

/* h2: 左線 + 薄い背景 + 微妙なグラデーション */
.article h2, .entry-content h2 {
  font-size: 1.4em !important;
  font-weight: 800;
  color: var(--text-main);
  background: linear-gradient(135deg, #f8fafd 0%, #f0f4f8 100%) !important;
  border: none !important;
  border-left: 4px solid var(--accent) !important;
  padding: 18px 22px !important;
  margin: 56px 0 28px !important;
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
  letter-spacing: -0.01em;
  line-height: 1.5;
  position: relative;
}

/* h3: 下線 + アクセント色のドット */
.article h3, .entry-content h3 {
  font-size: 1.2em !important;
  font-weight: 700;
  color: var(--text-main);
  border: none !important;
  background: none !important;
  padding: 0 0 10px 0 !important;
  margin: 48px 0 20px !important;
  border-bottom: 2px solid var(--border) !important;
  position: relative;
}

/* h3のアクセント部分 */
.article h3::after, .entry-content h3::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 40px;
  height: 2px;
  background: var(--accent);
}

/* h4: シンプルに太字 + 微妙なインデント感 */
.article h4, .entry-content h4 {
  font-size: 1.08em !important;
  font-weight: 700;
  color: var(--text-main);
  margin: 36px 0 14px;
  padding-left: 14px;
  border-left: 3px solid var(--border);
}

/* ===== 本文 ===== */
.article p, .entry-content p {
  color: var(--text-body);
  margin-bottom: 1.8em;
  line-height: 2.0;
}

/* 強調テキスト */
.article strong, .entry-content strong {
  font-weight: 700;
  color: var(--text-main);
}

/* 記事内リンク */
.article a, .entry-content a {
  color: var(--accent);
  text-decoration: underline;
  text-decoration-color: rgba(37, 99, 235, 0.3);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--duration) var(--ease);
}

.article a:hover, .entry-content a:hover {
  text-decoration-color: var(--accent);
}

/* ===== リスト ===== */
.article ul, .article ol {
  margin: 1.4em 0;
  padding-left: 1.6em;
}

.article ul {
  list-style: none;
  padding-left: 0;
}

.article ul li {
  position: relative;
  padding-left: 1.4em;
  margin-bottom: 0.7em;
  line-height: 1.85;
  color: var(--text-body);
}

/* カスタムチェックマーク風ビュレット */
.article ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 6px;
  height: 6px;
  background: var(--accent);
  border-radius: 50%;
}

.article ol li {
  margin-bottom: 0.7em;
  line-height: 1.85;
  color: var(--text-body);
}

/* ===== テーブル ===== */
.article table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.8em 0;
  font-size: 0.92em;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
}

.article th {
  background: var(--bg-subtle);
  font-weight: 700;
  padding: 14px 18px;
  border-bottom: 2px solid var(--border);
  text-align: left;
  color: var(--text-main);
  font-size: 0.9em;
  letter-spacing: 0.02em;
}

.article td {
  padding: 13px 18px;
  border-bottom: 1px solid var(--border-light);
  color: var(--text-body);
}

/* ゼブラストライプ */
.article tr:nth-child(even) td {
  background: rgba(248, 249, 251, 0.6);
}

.article tr:last-child td {
  border-bottom: none;
}

/* ホバーで行ハイライト */
.article tr:hover td {
  background: var(--accent-light);
  transition: background var(--duration) var(--ease);
}

/* ===== 画像 ===== */
.article img, .entry-content img {
  border-radius: var(--radius-sm);
  max-width: 100%;
  height: auto;
}

/* no-image対策: デフォルト画像を少しましに見せる */
.entry-card-thumb img[src*="no-image"],
.entry-card-thumb img[src*="no-thumbnail"] {
  opacity: 0.4;
  filter: grayscale(100%);
}

/* ===== 目次 ===== */
.toc, .table-of-contents {
  background: var(--white) !important;
  border: 2px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 28px 32px !important;
  margin: 2.5em 0;
  position: relative;
}

.toc-title {
  font-weight: 800 !important;
  font-size: 0.95em !important;
  margin-bottom: 16px !important;
  color: var(--text-main) !important;
  display: flex;
  align-items: center;
  gap: 8px;
}

/* 目次タイトル前のアイコン的装飾 */
.toc-title::before {
  content: '';
  display: inline-block;
  width: 4px;
  height: 18px;
  background: var(--accent);
  border-radius: 2px;
  flex-shrink: 0;
}

.toc a {
  color: var(--text-body) !important;
  font-size: 0.9em;
  line-height: 1.7;
  transition: color var(--duration) var(--ease);
}

.toc a:hover {
  color: var(--accent) !important;
}

.toc li {
  margin-bottom: 4px;
}

/* ===== ブロックエディタ: ボタン（CTA） ===== */
.wp-block-button__link {
  background: var(--accent) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  padding: 15px 32px !important;
  font-weight: 700 !important;
  font-size: 0.95em !important;
  letter-spacing: 0.02em;
  transition: background var(--duration) var(--ease),
              transform var(--duration) var(--ease),
              box-shadow var(--duration) var(--ease);
  cursor: pointer;
  display: inline-block;
  text-align: center;
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.2);
}

.wp-block-button__link:hover {
  background: var(--accent-hover) !important;
  color: var(--white) !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(37, 99, 235, 0.3);
}

/* CTAボタンをもう少し目立たせるラッパー */
.wp-block-buttons {
  margin: 32px 0 !important;
}

/* ===== 吹き出し ===== */
.speech-wrap {
  margin: 2em 0;
}

/* ===== 引用 ===== */
.article blockquote, .entry-content blockquote {
  background: var(--bg-subtle);
  border-left: 4px solid var(--border);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 20px 24px;
  margin: 1.8em 0;
  color: var(--text-sub);
  font-style: normal;
}

.article blockquote p {
  margin-bottom: 0.8em;
  color: var(--text-sub);
}

/* ===== コード ===== */
.article code, .entry-content code {
  background: var(--bg-subtle);
  color: var(--red);
  font-size: 0.88em;
  padding: 2px 6px;
  border-radius: 4px;
  font-family: 'SFMono-Regular', 'Consolas', 'Liberation Mono', 'Menlo', monospace;
}

.article pre, .entry-content pre {
  background: #1e293b !important;
  color: #e2e8f0;
  border-radius: var(--radius-sm);
  padding: 24px;
  overflow-x: auto;
  font-size: 0.88em;
  line-height: 1.7;
  margin: 1.8em 0;
}

.article pre code, .entry-content pre code {
  background: none;
  color: inherit;
  padding: 0;
  font-size: inherit;
}

/* ===== サイドバー ===== */
.sidebar, #sidebar {
  background: transparent !important;
}

.widget {
  background: var(--white) !important;
  border-radius: var(--radius) !important;
  padding: 24px !important;
  margin-bottom: 20px !important;
  box-shadow: var(--shadow-sm) !important;
  border: 1px solid var(--border-light) !important;
}

.widget-title {
  font-size: 0.88em !important;
  font-weight: 800 !important;
  color: var(--text-main) !important;
  border: none !important;
  background: none !important;
  padding: 0 0 12px 0 !important;
  margin-bottom: 16px !important;
  border-bottom: 2px solid var(--text-main) !important;
  letter-spacing: 0.03em;
}

/* ===== フッター ===== */
.footer, #footer {
  background: #111827 !important;
  color: #9ca3af !important;
  padding: 48px 0 32px !important;
}

.footer a { 
  color: #d1d5db !important; 
  transition: color var(--duration) var(--ease);
}
.footer a:hover { color: var(--white) !important; }

/* フッター内のテキストサイズ調整 */
.footer .footer-bottom {
  font-size: 0.82em;
  color: #6b7280;
}

/* ===== パンくず ===== */
.breadcrumb {
  font-size: 0.8em;
  color: var(--text-light);
  padding: 14px 0;
}

.breadcrumb a {
  color: var(--text-sub);
}
.breadcrumb a:hover {
  color: var(--accent);
}

/* ===== ブログカード ===== */
.blogcard-wrap {
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  box-shadow: none !important;
  transition: box-shadow var(--duration) var(--ease),
              border-color var(--duration) var(--ease);
}

.blogcard-wrap:hover {
  box-shadow: var(--shadow-md) !important;
  border-color: var(--accent-light) !important;
}

/* ===== SNS非表示 ===== */
.sns-share, .sns-follow, .sns-share-buttons, .sns-follow-buttons,
div[class*='sns-share'], div[class*='sns-follow'] {
  display: none !important;
}

/* ===== 不要な装飾削除 ===== */
.dark-mode-toggle { display: none !important; }

.go-to-top {
  border-radius: 50% !important;
  background: var(--accent) !important;
  color: var(--white) !important;
  box-shadow: var(--shadow) !important;
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  transition: opacity var(--duration) var(--ease),
              transform var(--duration) var(--ease);
}

.go-to-top:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md) !important;
}

/* ===== ページネーション ===== */
.pagination a, .pagination span {
  border-radius: var(--radius-xs) !important;
  font-size: 0.9em;
  font-weight: 600;
  transition: all var(--duration) var(--ease);
}

.pagination .current {
  background: var(--accent) !important;
  color: var(--white) !important;
  border-color: var(--accent) !important;
}

.pagination a:hover {
  background: var(--accent-light) !important;
  color: var(--accent) !important;
  border-color: var(--accent) !important;
}

/* ===== PR表記 ===== */
.article .pr-label,
.entry-content .pr-label {
  display: inline-block;
  font-size: 0.75em;
  font-weight: 700;
  color: var(--text-sub);
  background: var(--bg-subtle);
  padding: 4px 12px;
  border-radius: var(--radius-xs);
  margin-bottom: 16px;
  letter-spacing: 0.05em;
}

/* ===== 著者情報ボックス ===== */
.author-info {
  background: var(--bg-subtle) !important;
  border-radius: var(--radius) !important;
  padding: 28px !important;
  margin: 40px 0 !important;
  border: 1px solid var(--border-light) !important;
}

/* ===== 関連記事 ===== */
.related-entries {
  margin-top: 48px;
}

.related-entry-card {
  border-radius: var(--radius-sm) !important;
  transition: transform var(--duration) var(--ease);
}

.related-entry-card:hover {
  transform: translateY(-2px);
}

/* ===== コメント欄 ===== */
.comment-area {
  margin-top: 48px;
}

.comment-area .comment-respond {
  background: var(--bg-subtle);
  border-radius: var(--radius);
  padding: 28px;
}

/* ===== Cocoon固有ボックス装飾のオーバーライド ===== */
.blank-box, .information-box, .question-box, .alert-box {
  border-radius: var(--radius-sm) !important;
  border-width: 1px !important;
}

/* ===== アコーディオン ===== */
.toggle-wrap {
  border-radius: var(--radius-sm) !important;
  overflow: hidden;
}

/* =================================================
   モバイル最適化
   ================================================= */

@media (max-width: 768px) {
  body {
    font-size: 15.5px;
    line-height: 1.9;
    letter-spacing: 0.01em;
  }

  /* ヘッダーをコンパクトに */
  .header-container-in {
    padding: 8px 16px !important;
  }

  .logo-text, .site-name-text, .header .logo a {
    font-size: 1.1em !important;
  }

  /* メインコンテンツ */
  .wrap {
    padding: 8px 0;
  }

  .article, .content {
    padding: 32px 20px !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    border-bottom: 1px solid var(--border) !important;
  }

  /* タイトル */
  .entry-title {
    font-size: 1.35em !important;
    line-height: 1.5 !important;
    margin-bottom: 14px !important;
  }

  /* 見出し — 余白を詰めてテンポよく */
  .article h2, .entry-content h2 {
    font-size: 1.15em !important;
    padding: 14px 16px !important;
    margin: 40px 0 20px !important;
    border-radius: 0 var(--radius-xs) var(--radius-xs) 0 !important;
  }

  .article h3, .entry-content h3 {
    font-size: 1.05em !important;
    margin: 32px 0 14px !important;
    padding-bottom: 8px !important;
  }

  .article h4, .entry-content h4 {
    font-size: 1em !important;
    margin: 28px 0 10px !important;
  }

  /* 本文の余白を少し詰める */
  .article p, .entry-content p {
    margin-bottom: 1.4em;
    font-size: 0.95em;
  }

  /* リスト */
  .article ul, .article ol {
    padding-left: 1.2em;
    margin: 1.2em 0;
  }

  .article li, .article ul li {
    margin-bottom: 0.5em;
    font-size: 0.95em;
    line-height: 1.8;
  }

  /* テーブルを横スクロール可能に */
  .article .wp-block-table,
  .article table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    font-size: 0.85em;
  }

  .article th, .article td {
    padding: 10px 12px;
    white-space: nowrap;
  }

  /* 目次 */
  .toc, .table-of-contents {
    padding: 20px 22px !important;
    margin: 1.8em 0 !important;
  }

  .toc a { font-size: 0.85em; }

  /* 画像 */
  .article img, .entry-content img {
    border-radius: var(--radius-xs);
  }

  /* アイキャッチ */
  .eye-catch img {
    border-radius: 0 !important;
  }

  /* CTAボタン — タップしやすく */
  .wp-block-button__link {
    padding: 14px 28px !important;
    font-size: 0.95em !important;
    border-radius: var(--radius-sm) !important;
    width: 100%;
    box-sizing: border-box;
    text-align: center;
  }

  .wp-block-buttons {
    margin: 28px 0 !important;
  }

  /* ウィジェット */
  .widget {
    padding: 18px !important;
    margin-bottom: 14px !important;
    border-radius: var(--radius-sm) !important;
  }

  /* カード一覧 */
  .entry-card {
    border-radius: var(--radius-sm) !important;
  }

  .entry-card-title {
    font-size: 0.95em !important;
  }

  .entry-card-snippet {
    font-size: 0.8em !important;
    -webkit-line-clamp: 2;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  /* パンくず */
  .breadcrumb {
    font-size: 0.75em;
    padding: 8px 16px;
  }

  /* コメント欄 */
  .comment-area {
    padding: 0 !important;
  }

  /* 関連記事 */
  .related-entries {
    padding: 0 16px;
  }

  /* フッター */
  .footer, #footer {
    padding: 28px 16px !important;
    font-size: 0.85em;
  }

  /* 引用 */
  .article blockquote, .entry-content blockquote {
    padding: 16px 18px;
    margin: 1.4em 0;
  }

  /* コード */
  .article pre, .entry-content pre {
    padding: 18px;
    font-size: 0.82em;
  }
}

/* 小さめのスマホ */
@media (max-width: 480px) {
  .article, .content {
    padding: 24px 16px !important;
  }

  .entry-title {
    font-size: 1.2em !important;
  }

  .article h2, .entry-content h2 {
    font-size: 1.08em !important;
    padding: 12px 14px !important;
    margin: 36px 0 16px !important;
  }

  .article h3, .entry-content h3 {
    font-size: 1em !important;
  }

  .toc, .table-of-contents {
    padding: 16px 18px !important;
  }
}

/* ===== 印刷用スタイル ===== */
@media print {
  body { background: #fff; }
  .header, .footer, .sidebar, .navi, .sns-share, .sns-follow,
  .go-to-top, .pagination, .breadcrumb, .comment-area { display: none !important; }
  .article, .content { box-shadow: none !important; border: none !important; padding: 0 !important; }
}
