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

/************************************
** サブページ共通（page.php / single.php）
************************************/
.pt-page-hero {
  background:
    radial-gradient(ellipse at 90% -20%, rgba(47, 143, 126, .10), transparent 55%),
    linear-gradient(165deg, #EFF7F4 0%, #FBF4E8 100%);
  border-bottom: 1px solid var(--pt-line);
  padding: 44px 20px 40px;
  text-align: center;
}

.pt-page-hero-inner {
  max-width: 760px;
  margin: 0 auto;
}

.pt-page-title {
  font-family: var(--pt-font-display);
  font-size: 1.75em;
  font-weight: 700;
  color: var(--pt-primary-deep);
  line-height: 1.55;
  margin: 10px 0 0;
}

.pt-cat-chip {
  display: inline-block;
  background: #fff;
  border: 1px solid rgba(47, 143, 126, .35);
  color: var(--pt-primary-dark);
  border-radius: 999px;
  padding: 4px 14px;
  font-weight: 700;
  font-size: .8em;
  text-decoration: none;
}

.pt-cat-chip:hover {
  background: var(--pt-primary-pale);
}

.pt-page-meta {
  margin: 12px 0 0;
  font-size: .82em;
  color: var(--pt-ink-light);
  display: flex;
  gap: 14px;
  justify-content: center;
}

.pt-page-body {
  max-width: 760px;
  margin: 0 auto;
  padding: 36px 20px 24px;
}

/* 関連記事 */
.pt-related {
  margin: 40px 0 8px;
  background: #fff;
  border: 1px solid var(--pt-line);
  border-radius: 12px;
  padding: 20px 24px;
}

.pt-related-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--pt-font-display);
  font-size: 1em;
  color: var(--pt-primary-deep);
  margin: 0 0 10px;
  background: none;
  border: none;
  padding: 0;
}

.pt-related ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.pt-related li {
  padding: 8px 0;
  border-bottom: 1px dashed var(--pt-line);
}

.pt-related li:last-child {
  border-bottom: none;
}

.pt-related a {
  color: var(--pt-primary-dark);
  text-decoration: none;
  font-size: .92em;
  font-weight: 500;
}

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

/* 行動導線バンド（記事・固定ページ末尾） */
.pt-cta-band {
  background: linear-gradient(135deg, var(--pt-primary-dark), var(--pt-primary-deep));
  padding: 44px 20px;
  text-align: center;
  margin-top: 32px;
}

.pt-cta-band-title {
  font-family: var(--pt-font-display);
  color: #fff;
  font-size: 1.25em;
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 6px;
}

.pt-cta-band-sub {
  color: rgba(255, 255, 255, .82);
  font-size: .88em;
  margin: 0 0 20px;
}

.pt-cta-band-btns {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}

.pt-band-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: 999px;
  font-weight: 700;
  font-size: .95em;
  text-decoration: none;
  transition: all .25s ease;
}

.pt-band-btn--solid {
  background: var(--pt-cta);
  color: #fff !important;
}

.pt-band-btn--solid:hover {
  background: var(--pt-cta-hover);
}

.pt-band-btn--ghost {
  background: rgba(255, 255, 255, .12);
  color: #fff !important;
  border: 1.5px solid rgba(255, 255, 255, .55);
}

.pt-band-btn--ghost:hover {
  background: rgba(255, 255, 255, .22);
}

/************************************
** 一覧ページ（カテゴリ・ブログ）のエントリーカード
** 自動生成サムネイルを隠してテキストカード化
************************************/
.entry-card-thumb {
  display: none !important;
}

.entry-card-wrap {
  background: #fff;
  border: 1px solid var(--pt-line);
  border-radius: 12px;
  margin-bottom: 14px;
  transition: border-color .2s ease, box-shadow .2s ease;
}

.entry-card-wrap:hover {
  border-color: rgba(47, 143, 126, .45);
  box-shadow: var(--pt-card-shadow-hover);
}

.entry-card-wrap a.entry-card {
  padding: 18px 20px;
}

.entry-card-content {
  margin-left: 0 !important;
}

.entry-card-title {
  font-weight: 700;
  color: var(--pt-ink);
  font-size: 1.02em;
  line-height: 1.6;
}

.entry-card-wrap:hover .entry-card-title {
  color: var(--pt-primary-deep);
}

.entry-card-snippet {
  font-size: .85em;
  color: var(--pt-ink-light);
}

.entry-card-meta {
  font-size: .78em;
  color: var(--pt-ink-light);
}

/************************************
** 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) {
  /*必要ならばここにコードを書く*/
}
