/**
 * Post Content style overrides
 *
 * SWELL 親テーマの .post_content スタイル(濃紺の h2 ブロック・縞模様の h3 下線
 * ・派手な目次ボックスなど)が、リンカーンの落ち着いたトーンと不整合のため、
 * 子テーマ側で上書きして editorial 風に整える。
 *
 * 適用範囲は `.single-post__body.post_content`(我々の single.php の本文ラッパ)
 * に限定し、固定ページや管理画面側へは影響させない。
 */

/* =========================================================
 *  H1 / H2 / H3 / H4 — editorial magazine スタイル
 *
 *  方針:
 *  - 「派手な色ブロック」を完全に排し、上品な細線+アクセントで階層を表現
 *  - 余白を大きく取り、本文を読み進めたくなるリズムを作る
 *  - SWELL 親テーマの強い装飾には !important で確実に勝つ
 *  - 集客記事の読了率を上げるため、視線を上から下へ自然に誘導
 * ========================================================= */

/* ---- H1 ── 「章開き」の大見出し
 *  ・上に葉のシンボル(SVGアイコン)を置き、章の始まりを示す
 *  ・本文よりひと回り大きいフォントで、明確に階層トップであることを示す
 *  ・下にミントソフトの長い罫線、左にミントディープのアクセント
 *  ・H2(上罫線+左短アクセント)とは「上下を反転した意匠」で対比
 * ---------------------------------------------------------- */
.single-post__body.post_content h1,
.single-post__body.post_content h1.wp-block-heading {
  position: relative !important;
  margin: var(--space-5xl) 0 var(--space-2xl) !important;
  padding: 52px 0 var(--space-lg) !important; /* 上に葉アイコン分の余白 */
  font-family: var(--font-heading-jp) !important;
  font-size: clamp(28px, 4.4vw, 42px) !important; /* H2より明確に大きく */
  font-weight: var(--fw-bold) !important;
  color: var(--color-mint-text) !important;
  line-height: 1.45 !important;
  letter-spacing: 0.05em !important;
  /* 下に1pxの長い罫線(背景で描画) */
  background:
    linear-gradient(var(--color-mint-soft), var(--color-mint-soft)) left bottom / 100% 1px no-repeat !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* 葉のシンボル(章の始まりを示すサイン) */
.single-post__body.post_content h1::before {
  content: '' !important;
  position: absolute !important;
  top: 4px !important;
  left: 0 !important;
  width: 36px !important;
  height: 36px !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='none' stroke='%234B8F2C' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M6 26 C6 14 14 6 26 6 C26 18 18 26 6 26 Z'/><path d='M6 26 L20 12'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  background-color: transparent !important;
  border: none !important;
  display: block !important;
}

/* 下罫線に重なる、左端の太いアクセント(H2と上下逆) */
.single-post__body.post_content h1::after {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  bottom: -1.5px !important;
  top: auto !important;
  right: auto !important;
  width: 96px !important;
  height: 4px !important;
  background: linear-gradient(90deg, var(--color-mint-main), var(--color-mint-deep)) !important;
  background-image: linear-gradient(90deg, var(--color-mint-main), var(--color-mint-deep)) !important;
  background-color: transparent !important;
  border-radius: 2px !important;
  border: none !important;
  margin: 0 !important;
  box-shadow: none !important;
  display: block !important;
}

/* ---- H2 ── 細い罫線 + 左のアクセント ---- */
.single-post__body.post_content h2,
.single-post__body.post_content h2.wp-block-heading {
  position: relative !important;
  margin: var(--space-5xl) 0 var(--space-xl) !important;
  padding: var(--space-2xl) 0 0 !important;
  font-family: var(--font-heading-jp) !important;
  font-size: clamp(22px, 3vw, 30px) !important;
  font-weight: var(--fw-bold) !important;
  color: var(--color-mint-text) !important;
  line-height: 1.55 !important;
  letter-spacing: 0.04em !important;
  background: none !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  text-shadow: none !important;
}

.single-post__body.post_content h2::before,
.single-post__body.post_content h2.wp-block-heading::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: auto !important;
  bottom: auto !important;
  width: 100% !important;
  height: 1px !important;
  background: var(--color-mint-soft) !important;
  background-image: none !important;
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

.single-post__body.post_content h2::after,
.single-post__body.post_content h2.wp-block-heading::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  top: -2px !important;
  left: 0 !important;
  right: auto !important;
  bottom: auto !important;
  width: 56px !important;
  height: 4px !important;
  background: var(--color-mint-deep) !important;
  background-image: none !important;
  border-radius: 2px !important;
  border: none !important;
  margin: 0 !important;
}

/* ---- H3 ── 左の縦バー(グラデ) ---- */
.single-post__body.post_content h3,
.single-post__body.post_content h3.wp-block-heading {
  position: relative !important;
  margin: var(--space-3xl) 0 var(--space-md) !important;
  padding: var(--space-xs) 0 var(--space-xs) var(--space-lg) !important;
  font-family: var(--font-heading-jp) !important;
  font-size: clamp(18px, 2.2vw, 22px) !important;
  font-weight: var(--fw-bold) !important;
  color: var(--color-mint-text) !important;
  line-height: 1.55 !important;
  letter-spacing: 0.02em !important;
  background: none !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
}

.single-post__body.post_content h3::before,
.single-post__body.post_content h3.wp-block-heading::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.2em !important;
  bottom: 0.2em !important;
  right: auto !important;
  width: 5px !important;
  height: auto !important;
  background: linear-gradient(180deg, var(--color-mint-main) 0%, var(--color-mint-deep) 100%) !important;
  background-image: linear-gradient(180deg, var(--color-mint-main) 0%, var(--color-mint-deep) 100%) !important;
  border-radius: 2.5px !important;
  border: none !important;
}

/* ---- H4 ── 緑文字+小さなドットマーカー ---- */
.single-post__body.post_content h4,
.single-post__body.post_content h4.wp-block-heading {
  position: relative !important;
  padding: 0 0 0 var(--space-md) !important;
  border: none !important;
  background: none !important;
  margin: var(--space-2xl) 0 var(--space-sm) !important;
  font-family: var(--font-heading-jp) !important;
  font-size: clamp(16px, 1.8vw, 18px) !important;
  font-weight: var(--fw-bold) !important;
  color: var(--color-mint-deep) !important;
  line-height: var(--lh-heading) !important;
  letter-spacing: 0.02em !important;
}

.single-post__body.post_content h4::before,
.single-post__body.post_content h4.wp-block-heading::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.6em !important;
  width: 8px !important;
  height: 8px !important;
  background: var(--color-mint-main) !important;
  border-radius: 50% !important;
  display: block !important;
}

/* =========================================================
 *  目次(.p-toc.-double)
 * ========================================================= */
.single-post__body .p-toc.-double {
  background: var(--color-bg-mint);
  background-image: none;
  border-top: none;
  border-bottom: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-xl);
  margin: var(--space-2xl) auto;
  max-width: 720px;
}

.single-post__body .p-toc__ttl {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-mint-text);
  font-family: var(--font-heading-jp);
  font-weight: var(--fw-bold);
  font-size: var(--fs-small);
  margin: 0 0 var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
  letter-spacing: 0.04em;
}

.single-post__body .p-toc__ttl::before {
  color: var(--color-mint-deep);
  margin-right: var(--space-xs);
}

.single-post__body .p-toc__list {
  margin: 0;
  padding-left: 0;
}

.single-post__body .p-toc__list a {
  color: var(--color-text-main);
  text-decoration: none;
  transition: color var(--transition-base);
  font-size: var(--fs-small);
  line-height: 1.9;
}

.single-post__body .p-toc__list a:hover {
  color: var(--color-mint-deep);
}

/* =========================================================
 *  画像
 * ========================================================= */
.single-post__body .wp-block-image,
.single-post__body figure {
  margin: var(--space-xl) auto;
}

.single-post__body .wp-block-image img,
.single-post__body figure img,
.single-post__body img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  display: block;
}

/* SWELL の lazyload プレースホルダ(1x1 GIF)対策:
 * プレースホルダのまま読み込まれていない画像が空白になるのを防ぐ */
.single-post__body img.lazyload[src*="data:image/gif"] {
  background: var(--color-bg-mint);
  min-height: 120px;
  width: 100%;
}

.single-post__body figcaption {
  font-size: var(--fs-caption);
  color: var(--color-text-sub);
  text-align: center;
  margin-top: var(--space-xs);
  line-height: 1.7;
}

/* =========================================================
 *  本文 / 段落
 * ========================================================= */
.single-post__body.post_content p,
.single-post__body .wp-block-paragraph {
  font-size: var(--fs-body);
  line-height: 2;
  color: var(--color-text-main);
  margin: 0 0 var(--space-md);
}

/* =========================================================
 *  リスト
 * ========================================================= */
.single-post__body.post_content ul,
.single-post__body.post_content ol {
  margin: 0 0 var(--space-md);
  padding-left: var(--space-xl);
}

.single-post__body.post_content li {
  line-height: 1.95;
  margin-bottom: var(--space-xs);
  color: var(--color-text-main);
}

/* =========================================================
 *  引用(blockquote)
 * ========================================================= */
.single-post__body.post_content blockquote,
.single-post__body blockquote {
  background: var(--color-bg-mint);
  border-left: 3px solid var(--color-mint-main);
  border-radius: var(--radius-sm);
  padding: var(--space-md) var(--space-lg);
  margin: var(--space-lg) 0;
  font-style: normal;
}

.single-post__body.post_content blockquote::before {
  display: none;
}

/* =========================================================
 *  SWELL マーカー(蛍光ペン)を全てイエローソフトに統一
 * ========================================================= */
.single-post__body .mark_blue,
.single-post__body .mark_green,
.single-post__body .mark_yellow,
.single-post__body .mark_orange {
  background: linear-gradient(transparent 64%, var(--color-yellow-soft) 64%) !important;
  padding: 0 2px;
}

/* =========================================================
 *  SWELL キャプション付きボックス
 * ========================================================= */
.single-post__body .cap_box {
  background: var(--color-bg-mint);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin: var(--space-lg) 0;
}

/* =========================================================
 *  SWELL 吹き出し(c-balloon)をリンカーン色に
 * ========================================================= */
.single-post__body .c-balloon__text {
  background: var(--color-bg-mint) !important;
  border-color: var(--color-mint-soft) !important;
  color: var(--color-text-main) !important;
}

.single-post__body .c-balloon__before {
  border-right-color: var(--color-bg-mint) !important;
}

/* =========================================================
 *  SWELL カラーパレットのオーバーライド(派手な色を抑える)
 * ========================================================= */
.single-post__body .has-swl-main-color { color: var(--color-mint-deep) !important; }
.single-post__body .has-swl-main-background-color { background-color: var(--color-mint-deep) !important; }
.single-post__body .has-swl-main-thin-background-color { background-color: var(--color-mint-light) !important; }

/* インライン style の文字色は親に揃える(青/赤の派手な色をリセット) */
.single-post__body.post_content [style*="color"]:not(a):not([style*="color:var"]):not([style*="color: var"]) {
  color: inherit !important;
}

/* 強調表示の文字サイズが大きすぎる場合は抑える */
.single-post__body.post_content .has-huge-font-size,
.single-post__body.post_content .has-larger-font-size {
  font-size: var(--fs-h4) !important;
}

/* =========================================================
 *  関連記事 / 戻る導線の余白調整
 * ========================================================= */
.single-post__body + .single-post__related {
  margin-top: var(--space-3xl);
}

/* =========================================================
 *  記事末尾の集客導線CTA(.single-post__cta)
 *
 *  狙い:
 *  - 「読み終わった保護者」を、相談 / 見学 / もう少し情報収集 に分岐させる
 *  - メイン1本に絞り切らず、読者の検討フェーズに合わせて出口を用意
 *  - プライバシー配慮のため、強い命令表現は使わない
 * ========================================================= */
.single-post__cta {
  max-width: 880px;
  margin: var(--space-5xl) auto 0;
  padding: var(--space-3xl) var(--space-2xl);
  background:
    /* 右上に淡い円形グロー(余韻) */
    radial-gradient(circle at top right, rgba(107, 183, 60, 0.10) 0%, transparent 45%),
    /* 左下にも淡いグロー */
    radial-gradient(circle at bottom left, rgba(75, 143, 44, 0.07) 0%, transparent 40%),
    /* ベースは清潔な白 */
    #ffffff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(31, 63, 24, 0.04);
}

/* 左上の葉のあしらい(SVGデータURI)── トーン全体のシグネチャ */
.single-post__cta::before {
  content: '';
  position: absolute;
  top: -20px;
  left: -20px;
  width: 140px;
  height: 140px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100' fill='none' stroke='%236BB73C' stroke-width='1.2' stroke-linecap='round' stroke-linejoin='round' opacity='0.35'><path d='M20 80 Q40 30 80 20'/><path d='M28 70 Q35 55 50 50'/><path d='M38 60 Q45 48 60 45'/><path d='M48 50 Q55 40 70 38'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
}

/* 右下に小さな円のドット模様 */
.single-post__cta::after {
  content: '';
  position: absolute;
  bottom: -30px;
  right: -30px;
  width: 160px;
  height: 160px;
  background-image: radial-gradient(circle, var(--color-mint-soft) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
  opacity: 0.45;
  pointer-events: none;
}

/* 中身は装飾より前面に */
.single-post__cta > * {
  position: relative;
  z-index: 1;
}

.single-post__cta-head {
  text-align: center;
  margin-bottom: var(--space-xl);
}

.single-post__cta-eyebrow {
  font-family: var(--font-en, "Inter", sans-serif);
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  letter-spacing: 0.22em;
  color: var(--color-mint-deep);
  margin: 0 0 var(--space-sm);
}

.single-post__cta-title {
  font-family: var(--font-heading-jp);
  font-size: clamp(20px, 2.6vw, 28px);
  font-weight: var(--fw-bold);
  color: var(--color-mint-text);
  line-height: 1.6;
  letter-spacing: 0.04em;
  margin: 0 0 var(--space-md);
  padding: 0;
  background: none;
  border: none;
}
.single-post__cta-title::before,
.single-post__cta-title::after {
  content: none !important;
  display: none !important;
}

.single-post__cta-lead {
  font-size: var(--fs-body);
  line-height: 1.9;
  color: var(--color-text-main);
  margin: 0;
}

.single-post__cta-trust {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-xl);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm) var(--space-lg);
}

.single-post__cta-trust li {
  position: relative;
  padding-left: 22px;
  font-size: var(--fs-small);
  color: var(--color-mint-deep);
  font-weight: var(--fw-bold);
  line-height: 1.6;
}

.single-post__cta-trust li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.35em;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-mint-main);
  background-image:
    linear-gradient(45deg, transparent 40%, #fff 40%, #fff 55%, transparent 55%),
    linear-gradient(-45deg, transparent 55%, #fff 55%, #fff 70%, transparent 70%);
}

/* メインアクション 2 枚 */
.single-post__cta-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-2xl);
}

.cta-action {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-lg) var(--space-lg);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text-main);
  transition: all var(--transition-base);
  position: relative;
}

.cta-action:hover {
  transform: translateY(-2px);
  border-color: var(--color-mint-main);
  box-shadow: 0 8px 24px rgba(75, 143, 44, 0.12);
}

.cta-action__label {
  font-size: var(--fs-caption);
  letter-spacing: 0.08em;
  color: var(--color-mint-deep);
  font-weight: var(--fw-bold);
}

.cta-action__title {
  font-family: var(--font-heading-jp);
  font-size: clamp(17px, 1.8vw, 20px);
  font-weight: var(--fw-bold);
  color: var(--color-mint-text);
  line-height: 1.4;
}

.cta-action__hint {
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  line-height: 1.6;
  margin-top: 2px;
}

/* プライマリは緑塗りで視線を集める */
.cta-action--primary {
  background: linear-gradient(135deg, var(--color-mint-main) 0%, var(--color-mint-deep) 100%);
  border-color: var(--color-mint-deep);
  color: #fff;
}
.cta-action--primary .cta-action__label { color: rgba(255, 255, 255, 0.85); }
.cta-action--primary .cta-action__title { color: #fff; }
.cta-action--primary .cta-action__hint  { color: rgba(255, 255, 255, 0.85); }
.cta-action--primary:hover {
  border-color: var(--color-mint-deep);
  box-shadow: 0 10px 28px rgba(75, 143, 44, 0.28);
}

/* LINE主導線(面全体をLINEグリーンで塗る) */
.cta-action--line {
  background: #06C755;
  border-color: #05B34C;
}
.cta-action--line:hover {
  border-color: #05B34C;
  box-shadow: 0 10px 28px rgba(6, 199, 85, 0.3);
}
.cta-action__title-icon {
  display: inline-flex;
  vertical-align: -3px;
  margin-right: 6px;
}

/* LINE以外の窓口(フォーム・電話)への控えめな導線 */
.single-post__cta-altline {
  text-align: center;
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  margin: calc(-1 * var(--space-md)) 0 var(--space-2xl);
}
.single-post__cta-altline a {
  color: var(--color-mint-deep);
  font-weight: var(--fw-medium);
}

/* セカンダリ:検討中の方向け 4 リンク */
.single-post__cta-secondary {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.single-post__cta-secondary-label {
  font-size: var(--fs-small);
  color: var(--color-text-sub);
  margin: 0 0 var(--space-md);
  text-align: center;
  font-weight: var(--fw-bold);
}

.single-post__cta-secondary-links {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-sm);
}

.single-post__cta-secondary-links a {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: var(--space-md);
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  text-decoration: none;
  color: var(--color-text-main);
  background: var(--color-bg-mint);
  transition: all var(--transition-base);
}

.single-post__cta-secondary-links a:hover {
  border-color: var(--color-mint-soft);
  background: var(--color-mint-light);
}

.single-post__cta-secondary-links span {
  font-family: var(--font-heading-jp);
  font-size: var(--fs-small);
  font-weight: var(--fw-bold);
  color: var(--color-mint-text);
}

.single-post__cta-secondary-links small {
  font-size: 11px;
  color: var(--color-text-sub);
  line-height: 1.5;
}

.single-post__cta-fineprint {
  font-size: var(--fs-caption);
  color: var(--color-text-sub);
  text-align: center;
  margin: 0;
  line-height: 1.8;
}

.single-post__cta-fineprint a {
  color: var(--color-mint-deep);
  text-decoration: underline;
}

/* ---- レスポンシブ ---- */
@media (max-width: 640px) {
  .single-post__cta {
    padding: var(--space-2xl) var(--space-lg);
    border-radius: var(--radius-md);
  }
  .single-post__cta-actions {
    grid-template-columns: 1fr;
  }
  .single-post__cta-secondary-links {
    grid-template-columns: 1fr 1fr;
  }
  .single-post__cta-trust {
    justify-content: flex-start;
    gap: var(--space-xs) var(--space-md);
  }
}

/* sp-only ヘルパー(モバイル時のみ <br> を有効化) */
.sp-only { display: none; }
@media (max-width: 640px) {
  .sp-only { display: inline; }
}
