@charset "UTF-8";

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

/************************************
** デザイントークン
** 対象: 子育てに悩む保護者 → 落ち着き・温かみ・信頼感
************************************/
:root {
  /* メインカラー（青緑 = 安心・成長） */
  --pt-primary: #2F8F7E;
  --pt-primary-dark: #257263;
  --pt-primary-deep: #1C5A4E;
  --pt-primary-pale: #E9F4F1;

  /* アクセント（温かいオレンジ = 親しみ） */
  --pt-accent: #E8854D;
  --pt-accent-dark: #A85420;
  --pt-accent-pale: #FBEEE2;

  /* CTA ボタン */
  --pt-cta: #C1571E;
  --pt-cta-hover: #A84A15;

  /* ベース */
  --pt-bg: #FAF8F4;
  --pt-ink: #3B423F;
  --pt-ink-light: #656D68;
  --pt-line: #E6E1D8;

  /* 共通パーツ */
  --pt-radius: 12px;
  --pt-card-shadow: 0 2px 10px rgba(38, 70, 60, .07);
  --pt-card-shadow-hover: 0 8px 24px rgba(38, 70, 60, .13);

  /* 見出し用フォント（丸ゴ = 親しみ） */
  --pt-font-display: "Zen Maru Gothic", "Hiragino Maru Gothic ProN", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

/************************************
** ベース
************************************/
body {
  background-color: var(--pt-bg) !important;
  color: var(--pt-ink);
}

a {
  color: var(--pt-primary-dark);
  transition: color .2s ease;
}

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

/* インライン SVG アイコン共通 */
.pt-icon {
  vertical-align: -0.125em;
  flex-shrink: 0;
}

/************************************
** ヘッダー
************************************/
#header-container {
  background: #fff !important;
  border-bottom: 1px solid var(--pt-line);
}

.site-name-text {
  font-family: var(--pt-font-display);
  color: var(--pt-primary-deep) !important;
  font-weight: 700;
  letter-spacing: .05em;
}

#header .tagline {
  color: var(--pt-ink-light) !important;
}

/* グローバルナビ */
#navi {
  background: #fff !important;
}

#navi .navi-in > ul > li > a {
  color: var(--pt-ink);
  font-weight: 500;
  transition: background-color .2s ease, color .2s ease;
}

#navi .navi-in > ul > li > a:hover {
  background: var(--pt-primary-pale);
  color: var(--pt-primary-deep);
}

#navi .navi-in > ul > li.current-menu-item > a,
#navi .navi-in > ul > li.current_page_item > a {
  color: var(--pt-primary-dark);
  box-shadow: inset 0 -3px 0 var(--pt-primary);
}

/************************************
** 記事内見出し（基礎知識・ガイド記事の読みやすさ）
************************************/
.article h2 {
  background: var(--pt-primary-pale);
  border-left: 6px solid var(--pt-primary);
  border-radius: 8px;
  padding: .6em .8em;
  color: var(--pt-primary-deep);
}

.article h3 {
  border-left: 5px solid var(--pt-accent);
  border-bottom: 1px solid var(--pt-line);
  padding: .4em .6em;
}

.article h4 {
  border-top: none;
  border-bottom: 2px solid var(--pt-primary-pale);
  padding: .3em .1em;
}

.article a {
  color: var(--pt-primary-dark);
  text-decoration: underline;
  text-decoration-color: rgba(47, 143, 126, .35);
  text-underline-offset: 2px;
}

.article a:hover {
  color: var(--pt-accent-dark);
  text-decoration-color: rgba(201, 104, 47, .5);
}

/* 記事冒頭のアイキャッチは非表示
   （自動生成の「色ベタ+タイトル文字」画像でH1と重複し、トップの世界観を壊すため。OGP用には引き続き使用） */
.article .eye-catch-wrap,
.article .eye-catch {
  display: none;
}

/* 引用・テーブルなどの色味を合わせる */
.article blockquote {
  background: var(--pt-primary-pale);
  border-left: 4px solid var(--pt-primary);
}

.article table th {
  background: var(--pt-primary-pale);
}

/************************************
** フッター
************************************/
#footer {
  background: var(--pt-primary-deep) !important;
  color: rgba(255, 255, 255, .92);
}

#footer a {
  color: rgba(255, 255, 255, .85);
}

#footer a:hover {
  color: #fff;
}

#footer .footer-bottom,
#footer .copyright {
  color: rgba(255, 255, 255, .85); /* WCAG AA: 深緑背景でもコントラスト確保 */
}

/* ページトップボタンとコピーライトが重ならないよう余白を確保 */
#footer {
  padding-bottom: 64px;
}

/* フォローボックス（feedly/RSSアイコン）はサイト全体で非表示（古い印象を与えるため） */
.sns-follow {
  display: none !important;
}

/* パンくずリスト（生成り背景でもコントラスト確保） */
.breadcrumb,
.breadcrumb a,
.breadcrumb-caption {
  color: #57605C;
}

/* ページトップボタン */
#go-to-top .go-to-top-button {
  background: var(--pt-primary) !important;
  color: #fff !important;
  border-radius: 50%;
}

/************************************
** ボタン統一（Cocoon親テーマの黒い .btn を打ち消す）
************************************/
#content a.btn-primary,
#content a.btn-cta {
  background-color: var(--pt-cta) !important;
  color: #fff !important;
  border: none !important;
}

#content a.btn-primary:hover,
#content a.btn-cta:hover {
  background-color: var(--pt-cta-hover) !important;
  color: #fff !important;
}

#content a.btn-outline,
#content a.btn-ghost {
  background-color: #fff !important;
  color: var(--pt-primary-dark) !important;
  border: 2px solid var(--pt-primary) !important;
}

#content a.btn-outline:hover {
  background-color: var(--pt-primary) !important;
  color: #fff !important;
}

#content a.btn-ghost:hover {
  background-color: var(--pt-primary-pale) !important;
  color: var(--pt-primary-deep) !important;
}

#content a.btn-secondary {
  background-color: #6c757d !important;
  color: #fff !important;
  border: none !important;
}

/************************************
** 固定ページをすっきりさせる（ブログ的ノイズを除去）
************************************/
/* 記事冒頭のシェアボタンは全ページで非表示（記事末尾のみ残す） */
.sns-share.ss-top {
  display: none !important;
}

/* 固定ページではシェア・フォロー・日付メタを表示しない */
body.page .sns-share,
body.page .sns-follow,
body.page .date-tags-area,
body.page .post-date,
body.page .post-update {
  display: none !important;
}

/************************************
** SNSシェアボタン（原色ブロックを控えめなアウトライン型に）
************************************/
.sns-share.bc-brand-color a,
.sns-follow.bc-brand-color a {
  background: #fff !important;
  border: 1px solid var(--pt-line) !important;
  border-radius: 8px !important;
  color: var(--pt-ink-light) !important;
}

.sns-share.bc-brand-color a:hover,
.sns-follow.bc-brand-color a:hover {
  background: var(--pt-primary-pale) !important;
  border-color: var(--pt-primary) !important;
  color: var(--pt-primary-dark) !important;
}

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

/*834px以下*/
@media screen and (max-width: 834px) {
  /* Cocoonは menu-pc / menu-mobile の両方を出力するため、PC用は必ず隠す */
  #navi .navi-in > ul.menu-pc {
    display: none !important;
  }

  /* モバイルではナビを横スクロールのピル型に */
  #navi .navi-in > ul.menu-mobile {
    display: flex;
    flex-wrap: nowrap;
    justify-content: flex-start; /* center だとオーバーフロー時に左端が切れる */
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 6px 8px;
    gap: 4px;
  }

  #navi .navi-in > ul.menu-mobile::-webkit-scrollbar {
    display: none;
  }

  #navi .navi-in > ul.menu-mobile > li {
    flex: 0 0 auto;
    width: auto !important;
    border: none !important;
  }

  #navi .navi-in > ul.menu-mobile > li > a {
    padding: 8px 14px;
    border-radius: 999px;
    background: var(--pt-primary-pale);
    color: var(--pt-primary-deep);
    font-size: 14px;
    height: auto;
    line-height: 1.4;
  }

  #navi .navi-in > ul.menu-mobile > li.current-menu-item > a,
  #navi .navi-in > ul.menu-mobile > li.current_page_item > a {
    background: var(--pt-primary-dark); /* WCAG AA: 白文字とのコントラスト確保 */
    color: #fff;
    box-shadow: none;
  }

  /* 画面下部の固定フッターメニュー（アイコン未設定で星マークが並び壊れて見える）を非表示 */
  .mobile-footer-menu-buttons {
    display: none !important;
  }

  /* タップ展開のサブメニュー行（javascript.js が生成） */
  #pt-subnav {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 10px 12px;
    background: var(--pt-primary-pale);
    border-top: 1px solid rgba(47, 143, 126, .15);
  }

  #pt-subnav[hidden] {
    display: none;
  }

  .pt-subpill {
    background: #fff;
    border: 1px solid rgba(47, 143, 126, .3);
    border-radius: 999px;
    padding: 7px 14px;
    font-size: 13px;
    color: var(--pt-primary-deep);
    text-decoration: none;
  }

  /* 開いている親ピルを強調 */
  #navi .navi-in > ul.menu-mobile > li.pt-subnav-open > a {
    background: var(--pt-primary-dark);
    color: #fff;
  }

  /* 子持ち項目に展開インジケーターを付ける */
  #navi .navi-in > ul.menu-mobile > li.menu-item-has-children > a::after {
    content: " ▾";
    font-size: 11px;
    opacity: .7;
  }
}

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