@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Description: Cocoon専用の子テーマ
Theme URI: https://wp-cocoon.com/
Author: わいひら
Author URI: https://nelog.jp/
Template:   cocoon-master
Version:    1.1.3
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1023px以下*/
@media screen and (max-width: 1023px){
  /*必要ならばここにコードを書く*/
}

/*834px以下*/
@media screen and (max-width: 834px){
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px){
  /*必要ならばここにコードを書く*/
}
/* ============================================================
   マネたま速報 - カスタムスタイルシート
   テーマ: ホワイト × エメラルドグリーン（投資まとめブログ風）
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&display=swap');
/* --- カラー変数 --- */
:root {
  --color-primary:      #16a34a; /* エメラルドグリーン */
  --color-primary-dark: #15803d;
  --color-primary-light:#dcfce7;
  --color-accent:       #d97706; /* ゴールド */
  --color-accent-light: #fef3c7;
  --color-text:         #1e293b;
  --color-text-sub:     #64748b;
  --color-bg:           #f8fafc;
  --color-white:        #ffffff;
  --color-border:       #e2e8f0;
  --color-card-shadow:  0 2px 12px rgba(0,0,0,0.08);
  --color-card-shadow-hover: 0 8px 32px rgba(22,163,74,0.18);
  --radius:             10px;
}
/* --- 基本フォント --- */
body, .body {
  font-family: 'Noto Sans JP', 'Hiragino Kaku Gothic Pro', sans-serif !important;
  background-color: var(--color-bg) !important;
  color: var(--color-text) !important;
}
/* ============================================================
   ヘッダー
   ============================================================ */
#header {
  background: linear-gradient(135deg, #15803d 0%, #16a34a 60%, #22c55e 100%) !important;
  box-shadow: 0 2px 16px rgba(22,163,74,0.25) !important;
  padding: 0 !important;
}
.header-container {
  background: transparent !important;
}
/* サイト名 */
.site-name-text,
.site-name-text-link {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 1.5rem !important;
  letter-spacing: 0.02em;
  text-shadow: 0 1px 4px rgba(0,0,0,0.18);
}
/* キャッチコピー */
.site-description,
.tagline {
  color: rgba(255,255,255,0.85) !important;
  font-size: 0.82rem !important;
}
/* ロゴ画像がある場合のサイズ制御 */
.site-name img,
.header-logo img {
  max-height: 60px;
}
/* ============================================================
   グローバルナビゲーション
   ============================================================ */
#navi {
  background: var(--color-primary-dark) !important;
}
#navi .navi-in > ul > li > a {
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  padding: 12px 18px !important;
  transition: background 0.2s, color 0.2s;
  letter-spacing: 0.04em;
}
#navi .navi-in > ul > li > a:hover,
#navi .navi-in > ul > li.current-menu-item > a {
  background: rgba(255,255,255,0.15) !important;
  color: #ffffff !important;
}
/* ============================================================
   記事一覧（カード）
   ============================================================ */
.entry-card-wrap {
  background: var(--color-white) !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: var(--color-card-shadow) !important;
  overflow: hidden !important;
  transition: transform 0.22s cubic-bezier(.4,0,.2,1),
              box-shadow 0.22s cubic-bezier(.4,0,.2,1) !important;
  margin-bottom: 20px !important;
}
.entry-card-wrap:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--color-card-shadow-hover) !important;
}
/* サムネイル */
.entry-card-thumb img {
  transition: transform 0.3s ease !important;
}
.entry-card-wrap:hover .entry-card-thumb img {
  transform: scale(1.04) !important;
}
/* タイトル */
.entry-card-title {
  font-weight: 700 !important;
  font-size: 1.05rem !important;
  color: var(--color-text) !important;
  line-height: 1.55 !important;
}
.entry-card-wrap:hover .entry-card-title {
  color: var(--color-primary) !important;
}
/* スニペット */
.entry-card-snippet {
  font-size: 0.85rem !important;
  color: var(--color-text-sub) !important;
  line-height: 1.6 !important;
}
/* カテゴリラベル */
.cat-label {
  font-weight: 700 !important;
  font-size: 0.72rem !important;
  padding: 3px 8px !important;
  border-radius: 4px !important;
}
/* カテゴリ別カラー */
.cat-label-5,
[class*="cat-label-"] {
  background: var(--color-primary) !important;
  color: #fff !important;
}
/* 投稿日・カテゴリ情報エリア */
.entry-card-info {
  font-size: 0.8rem !important;
  color: var(--color-text-sub) !important;
}
/* ============================================================
   記事本文エリア
   ============================================================ */
.article {
  font-size: 1rem;
  line-height: 1.85;
}
.article h2 {
  border-left: 5px solid var(--color-primary) !important;
  border-bottom: 1px solid var(--color-primary-light) !important;
  padding: 10px 16px !important;
  background: var(--color-primary-light) !important;
  border-radius: 0 var(--radius) var(--radius) 0 !important;
  font-weight: 700 !important;
  color: var(--color-primary-dark) !important;
}
.article h3 {
  border-left: 4px solid var(--color-accent) !important;
  padding: 6px 12px !important;
  background: var(--color-accent-light) !important;
  border-radius: 0 6px 6px 0 !important;
  font-weight: 700 !important;
}
/* ============================================================
   サイドバー
   ============================================================ */
#sidebar {
  background: transparent !important;
}
.widget {
  background: var(--color-white) !important;
  border-radius: var(--radius) !important;
  border: 1px solid var(--color-border) !important;
  box-shadow: 0 1px 6px rgba(0,0,0,0.06) !important;
  overflow: hidden !important;
  margin-bottom: 20px !important;
  padding: 0 !important;
}
/* ウィジェットタイトル */
.widget-title,
.wp-block-heading,
.widget .wp-block-group > h2 {
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--color-primary-dark) 100%) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 0.9rem !important;
  padding: 10px 16px !important;
  margin: 0 !important;
  letter-spacing: 0.05em;
}
.widget > div,
.widget .inside {
  padding: 12px 14px !important;
}
/* 最新記事リスト */
.wp-block-latest-posts a {
  color: var(--color-text) !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  border-bottom: 1px solid var(--color-border);
  display: block;
  padding: 8px 0;
  transition: color 0.15s;
}
.wp-block-latest-posts a:hover {
  color: var(--color-primary) !important;
}
/* カテゴリリスト */
.wp-block-categories a {
  color: var(--color-text) !important;
  font-size: 0.88rem !important;
  display: flex;
  align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--color-border);
  transition: color 0.15s;
}
.wp-block-categories a::before {
  content: '▶';
  color: var(--color-primary);
  font-size: 0.6rem;
  margin-right: 6px;
}
.wp-block-categories a:hover {
  color: var(--color-primary) !important;
}
/* アーカイブリスト */
.wp-block-archives a {
  color: var(--color-text) !important;
  font-size: 0.88rem !important;
  display: block;
  padding: 7px 0;
  border-bottom: 1px solid var(--color-border);
}
.wp-block-archives a:hover {
  color: var(--color-primary) !important;
}
/* ============================================================
   フッター
   ============================================================ */
#footer {
  background: #0f172a !important;
  color: #94a3b8 !important;
  padding: 32px 0 20px !important;
}
#footer a,
.footer-bottom .site-name-text,
.footer-bottom .site-name-text-link {
  color: #cbd5e1 !important;
  font-size: 1rem !important;
}
#footer a:hover {
  color: #4ade80 !important;
}
.menu-footer a {
  color: #94a3b8 !important;
  font-size: 0.82rem !important;
  transition: color 0.15s;
}
.menu-footer a:hover {
  color: #4ade80 !important;
}
/* フッター著作権表示 */
#footer-bottom-content,
.footer-bottom-content {
  font-size: 0.78rem !important;
  color: #64748b !important;
}
/* ============================================================
   モバイル対応
   ============================================================ */
@media screen and (max-width: 834px) {
  .site-name-text {
    font-size: 1.15rem !important;
  }
  .entry-card-title {
    font-size: 0.97rem !important;
  }
  .entry-card-wrap {
    margin-bottom: 14px !important;
  }
  #navi .navi-in > ul > li > a {
    padding: 10px 12px !important;
    font-size: 0.82rem !important;
  }
}
@media screen and (max-width: 480px) {
  .site-name-text {
    font-size: 1rem !important;
  }
}
/* ============================================================
   トップへ戻るボタン
   ============================================================ */
.go-to-top-button {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-radius: 50% !important;
  box-shadow: 0 3px 12px rgba(22,163,74,0.4) !important;
}
/* ============================================================
   タグ（投稿詳細ページ）
   ============================================================ */
.tag-link,
.post-tags a {
  background: var(--color-primary-light) !important;
  color: var(--color-primary-dark) !important;
  border-radius: 4px !important;
  padding: 3px 10px !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  border: 1px solid var(--color-primary) !important;
  transition: background 0.15s;
}
.tag-link:hover,
.post-tags a:hover {
  background: var(--color-primary) !important;
  color: #fff !important;
}
/* ============================================================
   ページネーション
   ============================================================ */
.page-numbers {
  border: 1px solid var(--color-border) !important;
  color: var(--color-text) !important;
  border-radius: 6px !important;
  font-weight: 700 !important;
  transition: all 0.15s;
}
.page-numbers:hover,
.page-numbers.current {
  background: var(--color-primary) !important;
  color: #fff !important;
  border-color: var(--color-primary) !important;
}
/* ==========================================================
   AI要約・管理人コメントのスタイル設定
   ========================================================== */

/* ① AIによるスレッド要約（記事の冒頭） */
.matome-intro {
    font-size: 0.95rem;
    background: #f0fdfa; /* 爽やかな薄いエメラルドの背景 */
    border: 1px solid #ccfbf1;
    border-left: 5px solid #0d9488; /* 左側の太い緑の縦線 */
    border-radius: 4px;
    padding: 15px 20px;
    margin-bottom: 25px;
    color: #1f2937;
}

.matome-intro h5 {
    font-size: 1.05rem;
    font-weight: 700;
    color: #0d9488;
    margin: 0 0 8px 0;
}

.matome-intro p {
    margin: 0;
    line-height: 1.6;
}

/* ② 管理人コメント（記事の最後） */
.matome-comment {
    margin: 30px 0;
    padding: 15px 20px;
    background: #f8fafc; /* 薄いグレーの背景 */
    border: 1px solid #e2e8f0;
    border-left: 5px solid #64748b; /* 左側の太いグレーの縦線 */
    border-radius: 4px;
    font-size: 0.95rem;
    color: #334155;
}

/* 「管理人コメント」の見出しテキスト */
.matome-comment::before {
    content: '📝 管理人コメント';
    display: block;
    font-weight: 700;
    color: #475569;
    margin-bottom: 8px;
    font-size: 1rem;
}
/* ==============================================
   まとめブログ インデックスレイアウト（修正版）
   ============================================== */

.matome-post-list {
  max-width: 100%;
}

.matome-index-post {
  display: flex;
  flex-direction: row;
  gap: 20px;
  background: #fff;
  margin-bottom: 0;
  padding: 24px 0;
}

/* アイキャッチ画像の枠サイズ指定 */
.matome-index-thumb {
  flex: 0 0 200px;
  max-width: 200px;
  margin-bottom: 0;
}

.matome-index-thumb-img {
  width: 100%;
  height: 130px;
  object-fit: cover;
  border-radius: 6px;
  display: block;
}

.matome-index-body {
  flex: 1;
  min-width: 0; /* 折り返しバグ防止 */
}

.matome-index-title {
  font-size: 1.25rem;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: 8px;
  line-height: 1.4;
}

.matome-index-title a {
  color: #1a202c;
  text-decoration: none;
}

.matome-index-title a:hover {
  color: #059669;
  text-decoration: underline;
}

.matome-index-meta {
  font-size: 0.82rem;
  color: #6b7280;
  margin-bottom: 12px;
}

.matome-index-meta span {
  margin-right: 10px;
}

.matome-index-content {
  font-size: 0.95rem;
  line-height: 1.6;
}

/* AI要約カードのデザイン */
.matome-intro {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 6px;
  padding: 12px 16px;
  margin-bottom: 10px;
}

.matome-intro h5 {
  margin: 0 0 6px 0;
  font-size: 0.9rem;
  color: #15803d;
  font-weight: 700;
}

.matome-intro p {
  margin: 0;
  font-size: 0.9rem;
  color: #1e293b;
  line-height: 1.5;
}

/* 「続きを読む」ボタン */
.matome-read-more {
  margin: 16px 0 0;
  text-align: left;
}

.matome-read-more a {
  display: inline-block;
  padding: 8px 22px;
  background: #059669;
  color: #fff !important;
  border-radius: 4px;
  font-weight: 700;
  font-size: 0.88rem;
  text-decoration: none !important;
  transition: background 0.2s;
}

.matome-read-more a:hover {
  background: #047857;
}

/* 記事間の区切り線 */
.matome-index-separator {
  border: none;
  border-top: 1px solid #e5e7eb;
  margin: 0;
}

/* スマホ用レスポンシブ表示（画面幅640px以下） */
@media (max-width: 640px) {
  .matome-index-post {
    flex-direction: column; /* 縦並びにする */
    gap: 14px;
    padding: 20px 0;
  }
  .matome-index-thumb {
    flex: none;
    max-width: 100%;
  }
  .matome-index-thumb-img {
    height: auto;
    max-height: 180px;
  }
  .matome-read-more {
    text-align: center; /* ボタンを中央に */
  }
}