section {
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Yu Gothic', YuGothic, Verdana, Meiryo, 'M+ 1p', sans-serif;
}

section img {
  width: 100%;
}
/* =========================================================
   CTA
   ========================================================= */
section .cta_btn,
#price-btn02 {
  width: 100%;
  animation: none;
}
.fv-btn {
  margin: 5em 1em 8em;
  position: relative;
  z-index: 10;
}
/* =========================================================
   声
   ========================================================= */
@media (min-width: 481px) {
  .fcol.s-fcol4 {
    flex-basis: calc(100% / 2 - 1.4%);
    max-width: calc(100% / 2 - 1.4%);
  }
  .student_img {
    width: 60%;
  }
}
/* =========================================================
   price
   ========================================================= */
section#price {
  margin: 0 auto 3em;
}
/* =========================================================
   GLOBAL / HEADER / FIRST VIEW
   ========================================================= */
/* Header (固定) */
.lp-header {
  position: fixed;
  z-index: 1000;
}

/* ファーストビュー */
#fv_2209 {
  margin-top: 50px;
}
picture.fv_2209-img {
  display: block;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}
#fv-btn {
  margin: 2em auto 1em;
}
/* 背景（PC時の演出） */
@media (min-width: 768px) {
  #fv_2209 {
    position: relative;
    overflow: hidden;
    background-color: #27415b;
  }
  #fv_2209::before {
    content: '';
    display: block;
    background-image: url(/lp/wp/wp-content/themes/commu-lp-theme/lp/hanashikata-sc/images/fv_sp.webp);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    filter: blur(15px);
    opacity: 0.3;
  }
  .fv_2209-img {
    width: 100%;
  }
  .fv-btn {
    margin: 0 auto 3em;
  }
}
@media (min-width: 800px) {
  #fv_2209 {
    margin-top: 0;
  }
}
/* =========================================================
   お客様の声（#changed）
   ========================================================= */
#pageHome #manzokudo .img {
  margin: 1em auto;
  width: 75%;
}
#pageHome #manzokudo .caution {
  text-align: center !important;
  font-size: 10px;
}
.voice_acd-btn {
  margin: 1em auto 0.5em;
  width: 60%;
  position: relative;
}
.voice_acd-btn::before {
  content: '詳細を見る';
  background-color: #fff;
  font-size: 0.9em;
  color: #223f9a;
  font-weight: 600;
  line-height: 1;
  padding: 0.5em 2em;
  border-radius: 50vw;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #223f9a;
}
.voice_acd-btn.open_acd::before {
  content: '閉じる';
}
.voice_acd-btn.open_acd {
  margin: 0 auto 0.5em;
}
.voice-text {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
}
/* 開いた状態 */
.voice-text.is-open {
  max-height: 1000px;
}
.student_img {
  width: 85%;
  margin: 0 auto;
}

/* PC時（折返し解除など） */
@media (min-width: 768px) {
  .voice-text {
    max-height: none;
  }
  .voice_acd-btn {
    display: none;
  }
}

/* =========================================================
   こんなお悩みありませんか？（.problem）
   ========================================================= */
.problem {
  padding: 1em 1.5em 5em;
  margin: 0 auto;
  background-color: #f0f7ff;
}
.problem-inner {
  max-width: 480px;
  margin: 0 auto;
}
.problem-title {
  width: 85%;
  margin: -3em auto 0;
  position: relative;
  z-index: 1;
  background-color: #fff;
}
.problem-title img {
  width: 100%;
}
.problem-items {
  margin: 1em auto;
  width: 240px;
}
.problem-item {
  font-size: 1.3em;
  font-weight: 600;
  line-height: 1.5;
  /* margin-bottom: 0.5em; */
  text-indent: -2em;
  margin-left: 2em;
}
.problem-item strong {
  color: #ff4e00;
}
.problem-item:last-child {
  margin-bottom: 0;
}
.problem-item::before {
  content: '';
  display: inline-block;
  background: url(../images/icon_check.svg) no-repeat center / contain;
  width: 1.5em;
  height: 1.5em;
  transform: translateY(0.3em);
  margin-right: 0.5em;
}
.problem .problem-text {
  max-width: 760px;
  margin: 1.5em auto 0;
  /* ボタン見え防止・文章ブロック化 */
  border-radius: 10px;
  text-align: center;
}

/* 文章 */
.problem .problem-text p {
  margin: 0;
  /* 左ラインと距離を取る */
  font-size: 1.2em;
  line-height: 1.8;
  color: #000;
  font-weight: 600;
}

/* 段落間調整 */
.problem .problem-text p + p {
  margin-top: 0.6em;
}

/* 文章強調バリエーション */
.problem strong {
  font-weight: 900;
  color: #001e75;
}

/* マーカー強調（黄色系：ブランドカラーと馴染む） */
.problem .problem-text .mark {
  background: linear-gradient(transparent 60%, #ffeb3b 60%);
  padding: 0 0.05em;
  color: #000000;
}

/* 下線強調（知的・ビジネス向け） */
.problem .underline {
  text-decoration: none;
  background: linear-gradient(transparent 60%, #fff6a2 60%);
  color: #000000;
}

/* 色アクセント */
.problem .problem-text .accent {
  color: #03a9f4;
  font-weight: 800;
}

/* 改行制御（SPのみ） */
.problem .sp-only {
  display: inline;
}
@media (min-width: 768px) {
  .problem .sp-only {
    display: none;
  }
}
/* =========================================
   ③｜日常の伝え方が、評価をつくる（新規：eval3-）
   ※ .section-cause.v2 の思想を継承
   ========================================= */
.eval3-section {
  padding: 3em 1.5em 6em;
  position: relative;
  background-color: #edfaff; /* cause.v2 と同系トーン */
  /* overflow: hidden; */
}
.eval3-section::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/bg_cause02.webp) no-repeat center top / cover;
  position: absolute;
  inset: 0;
  opacity: 0.5;
  pointer-events: none;
}
.eval3-inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
}

/* 見出し（accents/size/余白は cause-title.-v2 を踏襲） */
.eval3-title {
  text-align: center;
  margin: -3em 0 1em; /* 前後セクションとの接続を美しく見せる */
  line-height: 1.5;
  letter-spacing: 0.02em;
}
.eval3-title-accent {
  display: inline-block;
  background: #0a1f66;
  color: #fff;
  padding: 0.25em 0.6em;
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(0, 30, 117, 0.16);
  font-weight: 900;
  font-size: clamp(1.25rem, 4.8vw, 1.75rem);
}
.eval3-title-sub {
  display: block;
  margin-top: 1em;
  color: #000;
  font-size: 0.7em; /* baseと整合 */
  font-weight: 600;
  line-height: 1.8;
}

/* 本文領域 */
.eval3-body {
  position: relative;
  text-align: left;
}

/* カード群（＝箇条書き3点） */
.eval3-cards {
  list-style: none;
  margin: 0 auto 1.6em;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  max-width: 960px;
}
@media (min-width: 768px) {
  .eval3-cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
}

/* カード */
.eval3-card {
  background: #ffffff;
  color: #fff;
  border-radius: 16px;
  padding: 0.5em 1em;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.12);
  display: grid;
  margin: 0 auto;
  width: 100%;
}

/* カードヘッダ（丸マーカー + 見出し） */
.eval3-card-head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 0.6em;
  min-height: 2.4em;
}
.eval3-badge {
  display: inline-grid;
  place-items: center;
  width: 1.1em;
  height: 1.1em;
  background: #0a1f66;
  color: #fff;
  border-radius: 50%;
  font-weight: 900;
  font-size: 1.2em; /* 「・」が見えやすいサイズ */
  line-height: 1;
  box-shadow: 0 8px 18px rgb(33 3 244 / 25%);
}
.eval3-card-title {
  margin: 0;
  font-size: 1.1em;
  font-weight: 800;
  color: #000;
  line-height: 1.6; /* 読みやすさ優先で少し広め */
  padding: 0.25em 0;
}

/* まとめ（insight 的ブロック） */
.eval3-summary {
  max-width: 760px;
  margin: 1.5em auto 0;
  text-align: center;
}

/* 段落（3行の“落ち”を作る） */
.eval3-summary p {
  margin: 0.12em 0;
  font-size: clamp(1.02rem, 3.2vw, 1.12rem);
  line-height: 1.8;
  color: #0a1f66;
  font-weight: 700;
}
.eval3-underline {
  text-decoration: none;
  background: linear-gradient(transparent 60%, #fff6a2 60%); /* baseのunderline表現に準拠 */
  color: #001e75;
  font-weight: 900;
}

/* SPの改行制御が必要な場合の補助（任意） */
.eval3-sp-only {
  display: inline;
}
@media (min-width: 768px) {
  .eval3-sp-only {
    display: none;
  }
}
/* =========================================
   ④｜なぜ、実力があっても評価が伸びないのか（新規：eval4-）
   ========================================= */
.eval4-section {
  position: relative;
  padding: 3em 1.5em;
}
.eval4-inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
}

/* 見出し（causeタイトル思想を踏襲しつつ色味だけ変更） */
.eval4-title {
  text-align: center;
  margin: -6em auto 1em; /* セクション接続を滑らかに */
  line-height: 1.5;
  letter-spacing: 0.02em;
  width: 85%;
}
.eval4-title-accent {
  display: block;
  /* オレンジ系アクセント */
  max-width: 320px;
  margin: 0 auto;
  width: 100%;
}
.eval4-title-sub {
  display: block;
  margin-top: 1em;
  /* 今回は補足文なし。必要になれば利用可 */
}

/* 本文（読みやすい幅・行間・サイズ） */
.eval4-body {
  position: relative;
  text-align: left;
}
.eval4-paragraphs {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
/* 段落（行ごとに“呼吸”をつける） */
.eval4-paragraphs p {
  margin: 0.28em 0;
  color: #3a2a12; /* 読みやすい濃いめのブラウン寄り */
  font-weight: 700;
  line-height: 1.9;
  font-size: clamp(1.02rem, 3.6vw, 1.16rem);
  letter-spacing: 0.01em;
  padding-left: 0.2em; /* 左ラインからの距離感 */
}

/* 最後の問いを“落ち”として視認強化 */
.eval4-paragraphs .eval4-emphasis {
  color: #2a1f0d;
  font-weight: 900;
  letter-spacing: 0.02em;
  background: linear-gradient(transparent 60%, #ffe9d6 60%);
  display: inline-block;
  padding: 0 0.1em;
  font-size: 1.3em;
}

/* アクセシビリティ：フォーカス可視化 */
.eval4-section :focus-visible {
  outline: 3px solid #ffeb3b;
  outline-offset: 3px;
  border-radius: 8px;
}
.eval4-il_why01 {
  width: 50%;
  margin: 1em auto -3em;
  max-width: 240px;
}
/* PC微調整 */
@media (min-width: 768px) {
  .eval4-section {
    padding-bottom: 3.6em;
  }
}
/* =========================================
   ⑤｜自己流では、なぜ変わらないのか（新規：eval5-）
   ========================================= */
.eval5-section {
  position: relative;
  padding: 2em 1.5em 3em;
  background: linear-gradient(0deg, #e9f5ff, #fff); /* ブルー系の淡背景で前段とトーン差別化 */
}

.eval5-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url(../images/bg_cause02.webp) no-repeat center top / cover; /* 既存テクスチャ流用 */
  opacity: 0.28; /* 読ませるため控えめに */
  pointer-events: none;
}

.eval5-section .eval5-inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
}

/* 見出し（causeタイトル思想を踏襲してブルーアクセント） */
.eval5-section .eval5-title {
  text-align: center;
  margin: 0em 0 1em;
  line-height: 1.5;
}
.eval5-section .eval5-title-accent {
  width: 80%;
  display: block;
  margin: 0 auto;
  max-width: 320px;
}
.eval5-section .eval5-title-sub {
  display: block;
  margin-top: 1em;
}

/* 本文 */
.eval5-body {
  position: relative;
}

/* =========================
   3カラムのアイキャッチ付きカード
   ========================= */
.eval5-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* グリッドレイアウト（SP:1列 → TB:2列 → PC:3列） */
.eval5-list--grid {
  display: grid;
  gap: 12px;
  grid-template-columns: 1fr; /* SP: 1列 */
  margin: 0 auto 1.2em;
  padding: clamp(0.6em, 2vw, 0.8em);
  max-width: 920px;
  background: transparent; /* 親ボックス装飾はカードへ */
  border: none;
  box-shadow: none;
}
@media (min-width: 768px) {
  .eval5-list--grid {
    grid-template-columns: repeat(3, 1fr); /* PC: 3列 */
  }
}

.eval5-list-item {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 12px;
  padding: 1em;
  background: #ffffff;
  border: 1px solid rgba(0, 30, 117, 0.1);
  border-radius: 14px;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.1);
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease;
}
.eval5-list-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.14);
}

.eval5-list-icon {
  display: grid;
  place-items: center;
  width: 2.4em;

  /* ブルー系の淡背景 */
}
.eval5-list-icon img {
  width: 100%;
  height: auto;
}

.eval5-list-text {
  color: #0b1f3d;
  font-weight: 800; /* 視認性を上げる */
  line-height: 1.6;
  font-size: clamp(1.02rem, 3.2vw, 1.12rem);
}

/* 既存の .eval5-list li 装飾を上書き（ドットやインデントを無効化） */
.eval5-list--grid li {
  list-style: none;
  position: relative;
}
.eval5-list--grid li::before {
  content: none !important;
}

/* =========================
   後半：段落ボックス（insight風）
   ========================= */
.eval5-paragraphs {
  max-width: 780px;
  margin: 0 auto;
  position: relative;
  text-align: center;
}

.eval5-paragraphs p {
  margin: 0.14em 0;
  color: #0a1f66;
  font-weight: 700;
  line-height: 1.9;
  font-size: clamp(1.02rem, 3.6vw, 1.16rem);
  letter-spacing: 0.01em;
}

/* 最後の文を自然に強調（薄ハイライト） */
.eval5-paragraphs .eval5-emphasis {
  color: #001e75;
  font-weight: 900;
  letter-spacing: 0.02em;
  background: linear-gradient(transparent 60%, rgba(0, 180, 255, 0.15) 60%);
  display: inline-block;
  padding: 0 0.1em;
}

/* アクセシビリティ：フォーカス可視化 */
.eval5-section :focus-visible {
  outline: 3px solid #ffeb3b;
  outline-offset: 3px;
  border-radius: 8px;
}

/* PC微調整 */
@media (min-width: 768px) {
  .eval5-section {
    padding-bottom: 3.4em;
  }
}
/* =========================================
   ⑥｜評価は「本番の再現性」で決まる（新規：eval6-）
   “気づき” ヒーロー調・タイポグラフィ強化
   ========================================= */
.eval6-section {
  position: relative;
  isolation: isolate;
  padding: 3em 1.5em;
  overflow: hidden;
  /* 切り替え感を強く：ダーク基調だが可読性確保 */
  background: linear-gradient(0deg, #6a75fa, #03a9f4);
  color: #eaf3ff;
}
/* 背景の“気づき”演出（放射グラデ＋薄いノイズ＋弱い動き） */
.eval6-bg {
  position: absolute;
  inset: -20% -10%;
  z-index: -1;
  background: radial-gradient(800px 400px at 70% 10%, rgba(3, 169, 244, 0.28), transparent 70%), radial-gradient(700px 380px at 30% 0%, rgba(255, 247, 91, 0.18), transparent 65%), radial-gradient(600px 300px at 50% 20%, rgba(4, 213, 218, 0.22), transparent 60%);
  filter: blur(10px) saturate(120%);
  animation: eval6Glow 12s ease-in-out infinite alternate;
  pointer-events: none;
  opacity: 0.9;
}
.eval6-section::before,
.eval7-section::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/bg_dot.webp) center / 500px;
  position: absolute;
  inset: 0;
  opacity: 0.1;
  pointer-events: none;
  z-index: -1;
}

@keyframes eval6Glow {
  0% {
    transform: translateY(0) scale(1);
    opacity: 0.85;
  }
  100% {
    transform: translateY(-2%) scale(1.02);
    opacity: 1;
  }
}

.eval6-inner {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

/* タイトル：行分割でメリハリ。キーワードはグラデ文字で強調 */
.eval6-title {
  margin: 0 auto 1em;
  line-height: 1.15;
  letter-spacing: 0.02em;
  text-align: center;
  max-width: 320px;
  width: 80%;
}

.eval6-title-line {
  display: block;
  font-weight: 900;
  font-size: clamp(1.6rem, 6.5vw, 3rem);
  color: #eaf3ff;
  text-shadow: 0 6px 26px rgba(0, 0, 0, 0.35);
}

.eval6-gradient {
  background: linear-gradient(90deg, #36d6ff 0%, #16c2f0 45%, #04d5da 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent; /* グラデ文字 */
  position: relative;
  white-space: nowrap;
}

.eval6-gradient::after {
  /* 下地の“気づきマーカー” */
  content: '';
  position: absolute;
  left: -0.15em;
  right: -0.15em;
  bottom: -0.05em;
  height: 0.4em;
  background: #3f51b5;
  z-index: -1;
  border-radius: 4px;
}

/* 本文：読み幅を絞り、1行ずつ“届く”リズムに */
.eval6-copy {
  max-width: min(44em, 90vw);
  margin: 0 auto;
  text-align: center;
  font-weight: 700;
}

.eval6-copy p {
  margin: 0.3em 0;
  line-height: 1.9;
  font-size: clamp(1.05rem, 3.8vw, 1.3rem);
  color: #fff;
}

/* “落ち”を引き締める強調 */
.eval6-copy .eval6-strong {
  color: #ffffff;
  font-weight: 900;
  letter-spacing: 0.01em;
  text-shadow: 0 3px 18px rgba(0, 0, 0, 0.35);
}

/* ラスト一行は反転プレートで “気づき” を明確化 */
.eval6-copy .eval6-invert {
  display: inline-block;
  margin-top: 0.35em;
  padding: 0.2em 0.6em;
  background: #fff;
  color: #071423;
  border-radius: 8px;
  box-shadow: 0 8px 26px rgba(0, 0, 0, 0.25);
  font-weight: 900;
}

/* フォーカス可視化（キーボード操作の見失い防止） */
.eval6-section :focus-visible {
  outline: 3px solid #ffeb3b;
  outline-offset: 4px;
  border-radius: 8px;
}
.eval6-il_notice01 {
  width: 60%;
  margin: 1em auto -4em;
  max-width: 240px;
}
/* =========================================
   ⑦｜原因（インパクト①②③）新規：eval7-
   ========================================= */
.eval7-section {
  position: relative;
  isolation: isolate;
  padding: 0 1.5em 3em;
  background: linear-gradient(0deg, #03a9f4, #6a75fa);
  color: #eaf3ff;
  overflow: hidden;
  margin: -2em auto 0;
}

.eval7-inner {
  max-width: 1120px;
  margin: 0 auto;
  position: relative;
}

/* タイトル：eval6の流れを継承（キーワードだけグラデに） */
.eval7-title {
  margin: 0 0 clamp(1.6rem, 4vw, 2.4rem);
  text-align: center;
  line-height: 1.15;
  letter-spacing: 0.02em;
}
.eval7-title-line {
  display: block;
  font-weight: 900;
  font-size: clamp(1.4rem, 5.8vw, 2.6rem);
  color: #eaf3ff;
  text-shadow: 0 6px 26px rgba(0, 0, 0, 0.35);
}
.eval7-grad {
  background: linear-gradient(90deg, #36d6ff 0%, #16c2f0 45%, #04d5da 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
}
.eval7-grad::after {
  content: '';
  position: absolute;
  left: -0.15em;
  right: -0.15em;
  bottom: 0.08em;
  height: 0.35em;
  background: linear-gradient(90deg, rgba(255, 247, 91, 0.5), rgba(255, 247, 91, 0));
  border-radius: 4px;
  z-index: -1;
}

/* 3カード（SP:縦/ TB:2列/ PC:3列） */
.eval7-grid {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  display: grid;
  gap: clamp(12px, 2.8vw, 18px);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .eval7-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.eval7-card {
  background: #fff;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  box-shadow:
    0 18px 40px rgba(0, 0, 0, 0.35),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  padding: 1.1em 1.1em 1.2em;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    border-color 0.18s ease;
}
/*
.eval7-card:hover {
  transform: translateY(-3px);
  box-shadow:
    0 26px 60px rgba(0, 0, 0, 0.44),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
  border-color: rgba(4, 213, 218, 0.35);
}
*/

/* カードヘッダ（番号バッジ＋タイトル） */
.eval7-card-head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.6em;
  padding-bottom: 0.5em;
  border-bottom: 1px solid rgb(84 84 84 / 18%);
}
.eval7-badge {
  display: inline-grid;
  place-items: center;
  width: 2.2em;
  height: 2.2em;
  border-radius: 50%;
  background: linear-gradient(135deg, #03a9f4, #04d5da);
  color: #fff;
  font-weight: 900;
  font-size: 1.05em;
  box-shadow: 0 10px 24px rgba(3, 169, 244, 0.35);
}
.eval7-card-title {
  margin: 0;
  font-weight: 900;
  font-size: 1.2em;
  color: #000;
  letter-spacing: 0.01em;
}

/* カード本文 */
.eval7-card-body p {
  margin: 0.45em 0;
  color: #000;
  line-height: 1.85;
  font-weight: 700;
  font-size: clamp(1rem, 3vw, 1.08rem);
}
.eval7-bullets {
  list-style: none;
  margin: 0.2em 0 0.4em;
  padding: 0;
}
.eval7-bullets li {
  color: #000;
  line-height: 1.8;
  font-weight: 700;
  font-size: clamp(0.98rem, 2.8vw, 1.06rem);
  padding-left: 0.2em; /* 先頭 "・" は原文どおり表示 */
}

/* まとめ（反転プレートで強い落ち） */
.eval7-summary {
  margin: 2em auto 0;
  max-width: min(860px, 94vw);
  text-align: center;
  color: #ffffff;
}
.eval7-summary p {
  margin: 0.12em 0;
  font-weight: 800;
  line-height: 1.85;
  font-size: clamp(1.02rem, 3.2vw, 1.16rem);
}
.eval7-summary .eval7-emphasis {
  font-weight: 900;
  color: #fff;
  letter-spacing: 0.01em;
  display: inline-block;
  padding: 0 0.08em;
}

/* フォーカス可視化（AA配慮） */
.eval7-section :focus-visible {
  outline: 3px solid #ffeb3b;
  outline-offset: 4px;
  border-radius: 8px;
}

/* 縦詰まり防止の余白調整（PC） */
@media (min-width: 768px) {
  .eval7-section {
    padding-bottom: clamp(3rem, 6vw, 4.2rem);
  }
}
/* =========================================================
   アプローチ v2（.section-approach.v2）
   ========================================================= */
.section-approach.v2 {
  padding: 3em 1.5em;
  position: relative;
  background-image: linear-gradient(0deg, #ffffff, #e7f2ff);
  /* overflow: hidden; */
}
.section-approach.v2::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: url(../images/bg_approach.svg) repeat center / 1500px;
  position: absolute;
  inset: 0;
  opacity: 0.2;
}
.section-approach.v2 .approach-inner {
  max-width: 960px;
  margin: 0 auto;
  position: relative;
}

/* 見出し */
.section-approach .approach-title.-v2 {
  margin: -4.5em 0 1em;
  text-align: center;
  line-height: 1.6;
  font-weight: 800;
  color: #021d76;
}
.section-approach .approach-title.-v2 .title-accent {
  display: inline-block;
  background: #03a9f4;
  color: #fff;
  padding: 0.25em 0.6em;
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(0, 30, 117, 0.16);
  font-size: clamp(1.25rem, 4.8vw, 1.8rem);
}
.section-approach .approach-title.-v2 .title-sub {
  display: block;
  margin-top: 0.6em;
  font-size: clamp(1rem, 3.6vw, 1.15rem);
  color: #001e75;
  font-weight: 600;
  opacity: 0.95;
}

/* 導入文 */
.section-approach.v2 .approach-intro {
  max-width: 760px;
  margin: 0 auto 1.2em;
  text-align: center;
}
.section-approach.v2 .approach-intro p {
  margin: 0.25em 0;
  font-size: 1em;
  line-height: 1.8;
  color: #000;
}
.section-approach.v2 .approach-intro .strong-line {
  font-weight: 800;
  color: #02a9f4;
  font-size: 1.14em;
  margin-top: 0.3em;
}

/* カード群 */
.section-approach.v2 .approach-cards {
  list-style: none;
  margin: 1.2em auto 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  max-width: 960px;
}
@media (min-width: 768px) {
  .section-approach.v2 .approach-cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
}

.section-approach.v2 .approach-card {
  background: #ffffff;
  border: 1px solid rgba(0, 30, 117, 0.08);
  border-radius: 16px;
  padding: 1em 1.2em 1.1em;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.25);
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 0.6em;
}
.section-approach.v2 .approach-card-img01 {
  width: 60%;
  margin: 0 auto -2em;
  max-width: 240px;
}
.section-approach.v2 .approach-card-img01 img {
  width: 100%;
}
.section-approach.v2 .card-head {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  column-gap: 0.6em;
  min-height: 3.5em;
  border-bottom: 1px solid #03a9f4;
  padding-bottom: 0.5em;
}
.section-approach.v2 .badge {
  display: inline-grid;
  place-items: center;
  color: #03a9f4;
  font-weight: 900;
  font-family: 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, sans-serif;
  font-size: 2.1em;
  line-height: 1;
  padding-right: 0.2em;
}
.section-approach.v2 .card-title {
  margin: 0;
  font-size: 1.12em;
  font-weight: 800;
  color: #0a1f66;
  line-height: 1.35;
}
.section-approach.v2 .card-body p {
  margin: 0;
  font-size: 0.9em;
  line-height: 1.6;
  color: #000000;
}

/* 改行制御 */
.section-approach.v2 .sp-only {
  display: inline;
}
@media (min-width: 768px) {
  .section-approach.v2 .sp-only {
    display: none;
  }
}

/* =========================================================
   この3つを仕組みとして（.section-steps.v2）
   ========================================================= */
.section-steps.v2 {
  padding: 3em 1.5em 4em;
  background-image: linear-gradient(0deg, #ffffff, #dee7fe);
  position: relative;
  overflow: hidden;
}
.section-steps.v2::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url(../images/bg_steps.png) repeat center top / 1000px;
  opacity: 0.25;
  pointer-events: none;
}
.section-steps.v2 .steps-inner {
  max-width: 960px;
  margin: 0 auto 3em;
  position: relative;
}

/* 見出し */
.section-steps.v2 .steps-v2-title {
  margin: 0 0 1.2em;
  text-align: center;
  font-weight: 800;
  color: #0a1f66;
  line-height: 1.4;
  letter-spacing: 0.02em;
  font-size: 1.2em;
}
.section-steps.v2 .steps-v2-title .title-line {
  font-size: 1em;
}
.section-steps.v2 .steps-v2-title .title-accent {
  display: inline-block;
  background: #0a1f66;
  color: #fff75b;
  border-radius: 10px;
  padding: 0.5em;
  margin: 0.2em 0;
  box-shadow: 0 8px 20px rgba(0, 30, 117, 0.16);
  font-size: 1.1em;
}

/* リード */
.section-steps.v2 .steps-v2-lead {
  text-align: center;
  margin: 0 auto 0.8em;
  max-width: 720px;
}
.section-steps.v2 .steps-v2-lead p {
  margin: 0;
  font-size: 1.05em;
  line-height: 1.8;
  color: #000;
}

/* チェックカード */
.section-steps.v2 .steps-v2-checks {
  list-style: none;
  margin: 1.2em auto 1.6em;
  padding: 0 0 0 1em;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  max-width: 380px;
}
.section-steps.v2 .check-card {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.6em;
  background: #ffffff;
  border: 1px solid rgba(0, 30, 117, 0.1);
  border-radius: 16px;
  padding: 0.9em 1em;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.24);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
  font-size: 1.1em;
}
.section-steps.v2 .check-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.26);
}
.section-steps.v2 .check-icon {
  display: inline-grid;
  place-items: center;
  width: 2em;
  height: 2em;
  background: #04d5da;
  color: #fff;
  border-radius: 10px;
  font-weight: 900;
  box-shadow: 0 8px 18px rgba(3, 169, 244, 0.3);
  margin-left: -2em;
}
.section-steps.v2 .check-text {
  font-weight: 700;
  color: #0a1f66;
}
.steps-img01 {
  width: 70%;
  margin: 0 auto -2em;
  max-width: 320px;
}
.steps-img01 img {
  width: 100%;
}
/* まとめ（強調帯） */
/* =========================================================
   Steps Summary（文章ブロック重視、ボタン感の排除）
   ========================================================= */
.section-steps.v2 .steps-v2-summary {
  /* レイアウト */
  max-width: 820px;
  margin: 1.6em auto 2.2em;

  /* 視認性：弱背景＋細枠＋淡いシャドウ（ボタン見えしない程度） */

  /* 文章らしさ */
  text-align: left;
}

.section-steps.v2 .steps-v2-summary p {
  margin: 0.2em 0;
  color: #0b1f3d; /* 濃すぎない本文色 */
  line-height: 1.6; /* 読みやすい行間 */
  letter-spacing: 0.01em;
  font-size: clamp(1rem, 3.6vw, 1.08rem);
}

/* 文章を“引用・宣言”っぽく見せる左ボーダー（過度な装飾を避ける） */
.section-steps.v2 .steps-v2-summary {
  position: relative;
  text-align: center;
}
.section-steps.v2 .steps-v2-summary::before {
  position: absolute;
  left: 0.8em;
  top: 1em;
  bottom: 1em;
  width: 4px;
  border-radius: 4px;
  background: linear-gradient(180deg, #001e75, #03a9f4);
  opacity: 0.35; /* 強すぎない存在感 */
}

/* 強調パターン（任意でHTML側に付与するクラス） */
.section-steps.v2 .steps-v2-summary strong {
  font-weight: 900;
  color: #001e75;
  font-size: 1.2em;
}

/* マーカー強調：背景に薄いイエロー（ブランド馴染ませ） */
.section-steps.v2 .steps-v2-summary .mark {
  background: linear-gradient(transparent 60%, rgba(255, 247, 91, 0.5) 60%);
  padding: 0 0.05em;
}

/* アクセント強調：シアン系で視認性UP（過度に強くない） */
.section-steps.v2 .steps-v2-summary .accent {
  color: #03a9f4;
  font-weight: 800;
}

/* 下線強調：にじみの少ないグラデ下線 */
.section-steps.v2 .steps-v2-summary .underline {
  text-decoration: none;
  background: linear-gradient(transparent 60%, rgba(255, 247, 91, 0.5) 60%);
  font-size: 1.2em;
}

/* 行間の小さな間（段落間の空気感） */
.section-steps.v2 .steps-v2-summary p + p {
  margin-top: 0.6em;
}

/* 改行制御 */
.section-steps.v2 .sp-only {
  display: inline;
}
@media (min-width: 768px) {
  .section-steps.v2 .sp-only {
    display: none;
  }
}

/* =========================================================
   コミュトレが選ばれる5つの理由（.reasons-section）
   ========================================================= */
.reasons-section {
  padding: 3em 1.5em;
  background-image: linear-gradient(0deg, #ffffff, #dee7fe);
  position: relative;
  overflow: hidden;
}
.reasons-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url(../images/bg_steps.png) repeat center / 1000px;
  opacity: 0.22;
  pointer-events: none;
}
.reasons-section .reasons-inner {
  max-width: 960px;
  margin: 0 auto 3em;
  position: relative;
}

/* 見出し */
.reasons-section .reasons-title {
  margin: 0 0 1.4em;
  text-align: center;
  line-height: 1.6;
  font-weight: 800;
  color: #0a1f66;
}
.reasons-section .reasons-title .title-accent {
  display: inline-block;
  background: #0a1f66;
  color: #fff75b;
  padding: 0.25em 0.6em;
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(0, 30, 117, 0.16);
  font-size: 1.5em;
  line-height: 1.5;
}
@media (min-width: 768px) {
  .reasons-section .sp-only {
    display: none;
  }
}
/* グリッド */
.reasons-section .reasons-list {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  display: flex;
  gap: 1em;
  place-content: center;
  flex-wrap: wrap;
  justify-content: space-between;
}

/* カード */
.reasons-section .reason-card {
  background: #ffffff;
  border: 1px solid rgba(0, 30, 117, 0.1);
  border-radius: 16px;
  padding: 1em 1.1em 1.15em;
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.22);
  row-gap: 0.6em;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  width: 100%;
  position: relative;
}
.reasons-section .reason-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.26);
}
@media (min-width: 769px) {
  .reasons-section .reason-card {
    width: calc(33% - 0.75em);
  }
  .reasons-section .reason-card:nth-child(4),
  .reasons-section .reason-card:nth-child(5) {
    width: calc(50% - 0.75em);
  }
}

/* ヘッダ（アイキャッチ + バッジ/タイトル） */
.reasons-section .reason-head {
  display: grid;
  align-items: center;
  column-gap: 0.8em;
  width: 100%;
  border-bottom: 1px solid #e8e8e8;
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
}
.reasons-section .reason-eyecatch {
  width: 60px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #f7fbff;
  border-radius: 10px;
}
.reasons-section .reason-eyecatch img {
  width: 60%;
}

.reasons-section .reason-meta {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 0.5em 0.6em;
  min-height: 3.5em;
}
.reasons-section .reason-badge {
  display: flex;
  width: 1.8em;
  height: 1.8em;
  border-radius: 0 10px 10px 0;
  background: #03a9f4;
  color: #fff;
  font-weight: 900;
  /* box-shadow: 0 8px 18px rgba(3, 169, 244, 0.28); */
  position: absolute;
  left: 0;
  font-size: 1.6em;
  font-family: 'Helvetica Neue', Helvetica, 'Segoe UI', Arial, sans-serif;
  line-height: 1;
  justify-content: center;
  align-items: center;
}
.reasons-section .reason-title {
  margin: 0;
  font-size: 1.1em;
  font-weight: 900;
  color: #0a1f66;
  line-height: 1.4;
  padding-left: 2.5em;
}
.reasons-section .reason-body {
  display: flex;
  width: calc(100% - 73px);
}
.reasons-section .reason-body p {
  margin: 0;
  font-size: 1em;
  line-height: 1.5;
  color: #000000;
}

/* =========================================================
   無料体験トレーニング（about_consulting）
   ========================================================= */
.about_consulting {
  background-color: #f2f2f2;
  position: relative;
  padding: 0 0 2em;
  margin-bottom: 0;
}
.about_consulting-box {
  max-width: 680px;
  margin: 0 auto;
  padding: 0;
}
.if_commu > img {
  display: block;
  width: 100%;
  margin: 0 auto;
  max-width: 800px;
  left: 50%;
  position: relative;
  transform: translateX(-50%);
}
.if_commu-txts {
  background: #fff;
  width: 90%;
  padding: 1em;
  border-radius: 14px;
  text-align: center;
  margin: -5em auto 0;
  max-width: 800px;
  position: relative;
  z-index: 10;
}
.if_commu-logo > img {
  width: 7em;
  display: inline-block;
  padding-bottom: 2px;
  margin-right: 6px;
}
.if_commu-logo {
  font-size: 1.2em;
  margin-bottom: 0.6em;
}
span.orange {
  color: #ff8f21;
}

/* PC向け最適化 */
@media (min-width: 768px) {
  .about_consulting::after {
    content: none;
  }
  .about_consulting {
    margin-bottom: 0;
  }
  .if_commu > img {
    margin: 0 auto;
    left: auto;
    transform: none;
  }
}

/* =========================================================
   体験当日の流れ（.section-flow）
   ========================================================= */
.section-flow {
  padding: 0 1.5em 4em;
  margin: 0 auto;
  background-color: #f2f2f2;
}
.section-flow-main_ttl {
  background-image: none;
  line-height: 1.4;
  padding: 0;
  text-align: center;
  color: #223f9a;
  font-size: 1.2em;
  max-width: 660px;
  margin: 0 auto 1em;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 600;
}
.section-flow-main_ttl::before,
.section-flow-main_ttl::after {
  content: '';
  display: inline-block;
  top: 50%;
  width: 8%;
  height: 3px;
  background-color: #223f9a;
  margin: 0 20px;
}
.flow-items {
  padding: 1em 0;
  max-width: 640px;
  margin: 0 auto;
}
.flow-item {
  background-color: #fff;
  border-radius: 10px;
  position: relative;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  padding: 1em;
  margin: 0 auto 2em;
}
.flow-item::after {
  content: '';
  display: inline-block;
  width: 0.8em;
  height: 0.8em;
  border-bottom: 4px solid #223f9a;
  border-right: 4px solid #223f9a;
  transform: rotate(45deg);
  position: absolute;
  bottom: -0.1em;
}
.flow-item-num {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 2em;
  font-weight: 900;
  color: #223f9a;
  line-height: 1;
  position: absolute;
  top: -0.5em;
  left: 0;
}
.flow-item-title {
  background-color: #223f9a;
  font-size: 0.9em;
  color: #fff;
  font-weight: 600;
  display: inline-block;
  line-height: 1;
  padding: 0.5em 2em;
  border-radius: 50vw;
  margin: -2em auto 0.5em;
  display: flex;
  align-items: center;
  justify-content: center;
}
.flow-item-cont {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
.flow-item-img {
  width: 5em;
}
.flow-item-img img {
  width: auto;
}
.flow-item-text {
  width: calc(100% - 7em);
  display: flex;
  align-items: center;
  font-size: 0.9em;
  line-height: 1.5;
}

/* 体験後にわかること */
.after_ux {
  margin: 0 auto 3em;
  border: 3px solid #223f9a;
  border-radius: 10px;
  padding: 1.4em;
  width: 100%;
  max-width: 620px;
  display: flex;
  flex-wrap: wrap;
  background: #fff;
  font-size: 0.9em;
}
.after_ux-title {
  font-size: 1.4em;
  font-weight: 600;
  background-color: #223f9a;
  line-height: 1;
  text-align: center;
  margin: -1.5em auto 0.8em;
  display: inline-block;
  padding: 0.4em 0;
  color: #fff;
  border-radius: 5px;
  margin-top: -2em;
  white-space: nowrap;
  width: 100%;
  max-width: 420px;
}
.after_ux-texts {
  width: 100%;
}
.after_ux-text {
  font-size: 1.1em;
  line-height: 1.4;
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  border-bottom: 1px dotted #ddd;
  position: relative;
  padding-left: 1.5em;
}
.after_ux-text::before {
  content: '';
  display: block;
  background: url(../images/icon-check.svg) no-repeat center / cover;
  width: 1em;
  height: 1em;
  position: absolute;
  left: 0;
  top: 0.2em;
}
.after_ux-text:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

/* PC向け */
@media (min-width: 768px) {
  .flow-items {
    font-size: 18px;
  }
  .flow-item {
    margin: 0 auto 2.5em;
    padding: 2em;
  }
  .flow-item-title {
    margin: -3em auto 0.5em;
  }
  .section-flow-main_ttl {
    font-size: 1.4em;
  }
}

/* =========================================================
   CTA（共通）
   ========================================================= */
.cta_btn::before {
  content: '今の話し方をプロが一緒にチェック';
  width: auto;
  padding: 0 1em;
  white-space: nowrap;
  font-size: 0.7em;
  height: 2em;
  display: flex;
  justify-content: center;
  align-items: center;
}
.modal-advice_cta::before {
  content: '今の話し方をプロが一緒にチェック';
}
section#media_result {
  margin: 0 auto;
  padding: 0 0 1em;
}

/* =========================================================
   返金バナー / 料金表（該当セクションに表示分のみ）
   ========================================================= */
.bn_refund {
  max-width: 420px;
  margin: 3em auto 0;
  font-size: 13px;
  line-height: 1.5;
}
.bn_refund-img {
  margin-bottom: 0.5em;
}
.bn_refund-text {
  font-size: 0.8em;
  padding-left: 1em;
  text-indent: -1em;
}

/* 価格テーブルの調整（ホーム） */
#pageHome #pricing table:after {
  content: none;
}
#pageHome #pricing table td:nth-child(4) {
  border: 4px solid #e60012;
}
#pageHome #pricing table td.price-td {
  border-bottom: solid 1px #ddd;
}
#pageHome #pricing table td.juko-td {
  border-top: solid 1px #ddd;
  border-bottom: solid 1px #ddd;
}
#pageHome #pricing table td.one-td {
  border-top: solid 1px #ddd;
}
/**/
#pageHome #changed #cvoices {
  top: 0;
}
#pageHome #manzokudo {
  padding: 2em 0 1em;
}
#pageHome #manzokudo .hl {
  font-size: 24px;
}
