/* ===== 教育的効果ページ専用CSS（あたたかみのあるデザイン） ===== */

/* ページ全体の背景をやわらかいクリーム色に */
body.page-template-page-educational-effects #home-v2,
#home-v2:has(.eff-hero) {
  background: #FFFAF0;
}

/* パンくず */
.eff-breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #9A8C78;
  margin-bottom: 8px;
}
.eff-breadcrumb a {
  color: #5D9E32;
  text-decoration: none;
}
.eff-breadcrumb a:hover { text-decoration: underline; }

/* ヒーロー */
.eff-hero {
  background: linear-gradient(135deg, #3A7D1F 0%, #5D9E32 60%, #F9A825 130%);
  padding: 56px 20px 64px;
  text-align: center;
  color: #fff;
  border-radius: 0 0 32px 32px;
}
.eff-hero__inner { max-width: 720px; margin: 0 auto; }
.eff-hero__label {
  display: inline-block;
  background: rgba(255,255,255,.22);
  border-radius: 20px;
  padding: 6px 18px;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 18px;
}
.eff-hero__title {
  font-size: clamp(28px, 5vw, 48px);
  font-weight: 900;
  line-height: 1.3;
  margin: 0 0 16px;
}
.eff-hero__title span { color: #FFF3C4; }
.eff-hero__desc {
  font-size: 16px;
  line-height: 1.85;
  color: rgba(255,255,255,.95);
  margin: 0 0 20px;
}
.eff-hero__meta {
  display: flex;
  justify-content: center;
  gap: 20px;
  font-size: 13px;
  color: rgba(255,255,255,.85);
}

/* コンテンツ幅 */
.eff-content { padding-bottom: 64px; }

/* リード文 */
.eff-lead {
  background: #FFF3DC;
  border-radius: 16px;
  padding: 24px 28px;
  margin: 36px 0;
  font-size: 16px;
  line-height: 1.85;
  color: #5A4A2E;
  box-shadow: 0 3px 10px rgba(180,140,60,0.08);
}

/* 目次 */
.eff-toc {
  background: #FFFFFF;
  border-radius: 18px;
  padding: 26px 28px;
  margin: 0 0 44px;
  box-shadow: 0 4px 14px rgba(140,110,60,0.10);
}
.eff-toc__title {
  font-weight: 800;
  font-size: 15px;
  margin: 0 0 14px;
  color: #5A4A2E;
}
.eff-toc__list {
  margin: 0;
  padding-left: 4px;
  list-style: none;
  counter-reset: eff-toc-counter;
}
.eff-toc__list li {
  counter-increment: eff-toc-counter;
  margin-bottom: 10px;
  font-size: 14px;
  padding-left: 30px;
  position: relative;
}
.eff-toc__list li::before {
  content: counter(eff-toc-counter);
  position: absolute;
  left: 0;
  top: -1px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #5D9E32;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: center;
}
.eff-toc__list a {
  color: #4A3A20;
  text-decoration: none;
  font-weight: 600;
}
.eff-toc__list a:hover { color: #5D9E32; text-decoration: underline; }

/* セクション：あたたかいカード型に */
.eff-section {
  background: #fff;
  border-radius: 20px;
  padding: 32px 26px;
  margin: 28px 0;
  box-shadow: 0 4px 16px rgba(140,110,60,0.08);
}
.eff-section__head {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 20px;
}
.eff-section__icon {
  font-size: 26px;
  line-height: 1;
  width: 52px;
  height: 52px;
  flex-shrink: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #FFE8B8, #FFD27D);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px rgba(180,140,60,0.18);
}
.eff-section__title {
  font-size: clamp(19px, 3vw, 24px);
  font-weight: 800;
  color: #3A2E1A;
  margin: 0;
}
.eff-section p {
  font-size: 15px;
  line-height: 1.9;
  color: #5A4E3C;
  margin: 0 0 16px;
}

/* ポイントボックス */
.eff-point {
  background: #FFF8EC;
  border-radius: 14px;
  padding: 22px 24px;
  margin: 18px 0;
}
.eff-point h3 {
  font-size: 13px;
  font-weight: 800;
  color: #C97A1F;
  margin: 0 0 12px;
  letter-spacing: .04em;
}
.eff-point ul {
  margin: 0;
  padding-left: 4px;
  list-style: none;
}
.eff-point ul li {
  font-size: 14px;
  line-height: 1.85;
  color: #5A4E3C;
  margin-bottom: 8px;
  padding-left: 24px;
  position: relative;
}
.eff-point ul li::before {
  content: "🌱";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 13px;
}

/* 吹き出し */
.eff-callout {
  background: #EAF6DC;
  border-radius: 14px;
  padding: 18px 22px;
  margin: 18px 0;
  font-size: 14px;
  line-height: 1.85;
  color: #2A5A15;
}

/* 保護者の声（あたたかい吹き出し型） */
.eff-voice {
  background: #FFF6E9;
  border-radius: 16px;
  padding: 20px 22px 18px;
  margin: 20px 0;
  position: relative;
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.eff-voice::before {
  content: "💬";
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #FFE3B3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}
.eff-voice__text {
  font-size: 14px;
  line-height: 1.85;
  color: #5A4E3C;
  margin: 0 0 8px !important;
}
.eff-voice__from {
  font-size: 12px;
  color: #9A8262;
  margin: 0 !important;
  font-weight: 600;
}

/* 2カラムグリッド */
.eff-grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin: 18px 0;
}
@media (min-width: 640px) {
  .eff-grid-2 { grid-template-columns: 1fr 1fr; }
}
.eff-grid-2__item {
  background: #FFF8EC;
  border-radius: 14px;
  padding: 22px;
}
.eff-grid-2__item h3 {
  font-size: 14px;
  font-weight: 800;
  color: #5D9E32;
  margin: 0 0 12px;
}
.eff-grid-2__item ul {
  margin: 0;
  padding-left: 18px;
}
.eff-grid-2__item li {
  font-size: 13px;
  line-height: 1.85;
  color: #5A4E3C;
}

/* 注意点セクション */
.eff-section--caution .eff-section__icon {
  background: linear-gradient(135deg, #FFD3C2, #FFAE8E);
}
.eff-section--caution .eff-section__title { color: #C2491F; }
.eff-caution-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  margin-top: 18px;
}
@media (min-width: 640px) {
  .eff-caution-list { grid-template-columns: repeat(3, 1fr); }
}
.eff-caution-item {
  background: #FFF3E0;
  border-radius: 14px;
  padding: 22px;
}
.eff-caution-item h3 {
  font-size: 14px;
  font-weight: 800;
  color: #C2491F;
  margin: 0 0 8px;
}
.eff-caution-item p {
  font-size: 13px !important;
  color: #5A4E3C !important;
  margin: 0 !important;
}

/* まとめ */
.eff-summary {
  background: linear-gradient(135deg, #FFF3DC, #EAF6DC);
  border-radius: 20px;
  padding: 32px 28px;
  margin: 40px 0;
  box-shadow: 0 4px 16px rgba(140,110,60,0.08);
}
.eff-summary h2 {
  font-size: 21px;
  font-weight: 800;
  color: #3A6B1A;
  margin: 0 0 16px;
}
.eff-summary p {
  font-size: 15px;
  line-height: 1.9;
  color: #4A4030;
  margin: 0 0 12px;
}
.eff-summary p:last-child { margin: 0; }

/* CTA */
.eff-cta {
  background: linear-gradient(135deg, #3A6B1A, #5D9E32);
  border-radius: 20px;
  padding: 40px 32px;
  text-align: center;
  margin: 40px 0;
  color: #fff;
}
.eff-cta__label {
  font-size: 12px;
  color: #FFE8B8;
  letter-spacing: .1em;
  text-transform: uppercase;
  margin: 0 0 8px;
  font-weight: 700;
}
.eff-cta__title {
  font-size: clamp(20px, 3vw, 28px);
  font-weight: 800;
  margin: 0 0 12px;
}
.eff-cta__text {
  font-size: 14px;
  color: rgba(255,255,255,.9);
  margin: 0 0 24px;
  line-height: 1.85;
}
.eff-cta .hv2-btn--green {
  display: inline-block;
  background: #F9A825;
  color: #3A2E0A !important;
  padding: 14px 36px;
  border-radius: 50px;
  font-weight: 800;
  font-size: 16px;
  text-decoration: none;
  transition: background .2s, transform .15s;
}
.eff-cta .hv2-btn--green:hover { background: #FFC04D; transform: translateY(-1px); }

/* 関連記事 */
.eff-related { margin-top: 44px; }
.eff-related__title {
  font-size: 18px;
  font-weight: 800;
  color: #3A2E1A;
  margin: 0 0 20px;
}
