@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&display=swap');
/* ===================================================================
   CSS Custom Properties（カラー・フォント・余白）
   =================================================================== */
:root {
  /* --- カラーパレット --- */
  --color-primary: #004C26;        /* メイン：ダークグリーン（見出し・テキスト） */
  --color-primary-deep: #004D2C;   /* Kaitoke Green（都道府県ボタン） */
  --color-cyan: #00B8EE;           /* シアン（h3見出し・帯） */
  --color-cyan-light: #6ED7F5;     /* ライトシアン */
  --color-cyan-mid: #30C5F1;       /* 中間シアン */
  --color-blue: #006DBB;           /* ブルー（受講回数バッジ・声見出し） */
  --color-blue-deep: #0090DA;      /* 深いブルー（日付） */
  --color-blue-alt: #0098EE;       /* 青（さかのぼり最下段） */
  --color-red: #E6204D;            /* 赤（CTAボタン・点数UP） */
  --color-red-alt: #E51F4D;        /* 赤（40秒強調） */
  --color-red-text: #E21F4D;       /* 赤（声の強調テキスト） */
  --color-orange: #ED6C00;         /* オレンジ（資料請求ボタン） */
  --color-yellow: #F5E428;         /* 黄（ハイライト背景） */
  --color-yellow-light: #FFF471;   /* 薄黄（受講例タグ） */
  --color-yellow-mark: #FFF53C;    /* 黄（見出し強調） */
  --color-green-light: #A0C11C;    /* 黄緑（ピッタリ帯背景） */
  --color-green-border: #94C33A;   /* 黄緑（タグ枠線） */
  --color-green-tag: #A7CA00;      /* 黄緑（受講例カード枠） */

  --color-text: #3E3A39;           /* 本文テキスト */
  --color-white: #FFFFFF;

  /* --- 背景色 --- */
  --bg-cream: #FFF8D8;             /* CTAバナー背景 */
  --bg-lightblue: #EAF8FD;         /* 成績/声/FAQ背景 */
  --bg-mint: #F0F8F5;              /* 教室を探す背景 */
  --bg-table-head: #E0EED7;        /* 表のヘッダー背景 */

  /* --- フォントサイズ（SPベース） --- */
  --fs-h2: 28px;
  --fs-h3: 26px;
  --fs-h4: 20px;
  --fs-section-title: 28px;        /* section-heading */
  --fs-body: 16px;
  --fs-body-lg: 18px;
  --fs-small: 14px;

  /* --- 余白 --- */
  --space-section: 40px;           /* セクション内パディング（SP） */
  --space-gutter: 16px;            /* 左右ガター（SP） */
  --content-max: 1304px;           /* PCコンテンツ最大幅 */

  /* --- フォント --- */
  --font-base: 'Noto Sans JP', sans-serif;
}

/* pa無効化 */
.pa-area-kansai #body_wrap,
.pa-area-kanto #body_wrap,
div#body_wrap{
  background-color:transparent!important;
}
.l-container{
  max-width: none!important;
  padding-left: 0!important;
  padding-right: 0!important;
}
/* ヘッダー内の l-container を元の状態に戻す */
#header .l-container {
  max-width: revert !important;
  padding-left: revert !important;
  padding-right: revert !important;
}
/* box-sizing もヘッダーだけ除外（念のため） */
#header *,
#header *::before,
#header *::after {
  box-sizing: revert;
}
.l-sidebar{
  display: none!important;
}
/* h1対応 */
.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  margin: -1px; padding: 0;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}




/* PC版で上書きするサイズ */
@media (min-width: 768px) {
  :root {
    --fs-h2: 50px;
    --fs-h3: 46px;
    --fs-h4: 24px;
    --fs-section-title: 50px;
    --fs-body: 22px;
    --fs-body-lg: 24px;
    --fs-small: 16px;
    --space-section: 80px;
    --space-gutter: 48px;
  }
}

/* ===================================================================
   リセット & ベース
   =================================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-base);
  font-weight: 400;
  color: var(--color-text);
  background: var(--color-white);
  line-height: 1.7;
}

.tpl-summer h2,
.tpl-summer h3,
.tpl-summerh4,
.tpl-summer p { margin: 0; }

/* ページ全体のラッパー（中央寄せ） */
.tpl-summer {
  width: 100%;
  margin: 0 auto;
}
/* 中身を最大幅に制限 */
.inner {
  max-width: 1170px;
  margin: 0 auto;
  padding: 0 20px; /* 端のスペースも確保 */
}

/* セクション共通の左右ガター付きコンテナ */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin: 0 auto;
  padding-left: var(--space-gutter);
  padding-right: var(--space-gutter);
}

/* ===================================================================
   共通コンポーネント
   =================================================================== */

/* --- section-heading：大見出し＋下線デコレーション --- */
.section-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  text-align: center;
}
.section-heading h2 {
  font-size: clamp(16px, 6vw, 32px);
  font-weight: 800;
  color: var(--color-primary);
  line-height: 1.3;
}
/* 下線デコレーション（緑の二重線風） */
.section-heading::after {
  content: "";
  display: block;
  width: 80px;
  height: 4px;
  border-radius: 2px;
  background: var(--color-yellow-mark);
  position: relative;
}
@media (min-width: 768px) {
  .section-heading { gap: 26px; }
  .section-heading::after { width: 116px; }
}

/* --- cta-banner：赤ボタン＋オレンジボタン --- */
.cta-banner {
  background: var(--bg-cream);
  padding: 14px 0 22px;   /* SP高さ274px相当 */
}
.cta-banner .inner {
  display: flex;
  flex-direction: column;
  align-items: end;
  justify-content: center;
  gap: 12px;
}
.cta-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  width: 100%;
}
.cta-label {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text);
  text-align: center;
}
.cta-label .num { font-size: 26px; font-weight: 600; color: var(--color-red-alt); line-height: 1;}
.cta-label .num-unit { font-size: 20px; color: var(--color-red-alt); }

.cta-button {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  max-width: 340px;
  height: 64px;
  border-radius: 50px;
  color: var(--color-white);
  font-weight: 600;
  text-decoration: none;
  filter: drop-shadow(0 2px 2px rgba(0,0,0,0.3));
  box-shadow: inset 0 4px 4px rgba(255,255,255,0.25);
}
.cta-button--trial::before {
  content: "";
  position: absolute;
  display: block;
  background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,0.9));
  width: 50px;
  height: 50px;
  top: -60px;
  left: -60px;
  animation: cta-shine-run 3s ease-in infinite;
}
@keyframes cta-shine-run {
  0%   { transform: scale(0)   rotate(50deg); opacity: 0; }
  40%  { transform: scale(1)   rotate(50deg); opacity: 1; }
  60%  { transform: scale(30)  rotate(50deg); opacity: 0; }
  100% { transform: scale(250) rotate(50deg); opacity: 0; }
}
.cta-button--trial { background: var(--color-red); }
.cta-button--doc   { background: var(--color-orange); }
.cta-button {
  transition: opacity 0.2s ease;
}
.cta-button:hover  { text-decoration: none; opacity: 0.85; }
.cta-button .label { font-size: clamp(16px, 5vw, 22px); white-space: nowrap; }
.cta-button .label .small { font-size: 0.9em; }
/* 右向き三角矢印（CSSで描画） */
.cta-button .arrow {
  width: 0; height: 0;
  border-style: solid;
  border-width: 9px 0 9px 14px;
  border-color: transparent transparent transparent var(--color-white);
  transition: transform 0.2s ease;
}
.cta-button:hover .arrow {
  transform: translateX(4px);
}

@media (min-width: 768px) {
  .cta-banner {
    padding: 40px 0;   /* PC高さ212px相当 */
  }
  .cta-banner .inner {
    flex-direction: row;
  }
  .cta-block {
    flex: 1;
    min-width: 0;
  }
  .cta-label { font-size: 24px; }
  .cta-label .num { font-size: 36px; }
  .cta-label .num-unit { font-size: 24px; }
  .cta-button { width: 100%; max-width: 440px; height: 80px; }
  .cta-button .label { font-size: clamp(18px, 2.5vw, 26px); }
}

/* --- 成績UPカード --- */
.result-card {
  background: var(--color-white);
  filter: drop-shadow(0 2px 1px rgba(0,0,0,0.08));
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 12px 8px;
  width: 100%;
}
.result-card .name {
  font-size: clamp(10px, 4vw, 13px);
  color: var(--color-primary);
  text-align: center;
}
.result-card .badge {
  background: var(--color-blue);
  color: var(--color-white);
  font-size: clamp(10px, 3.6vw, 24px);
  font-weight: 600;
  padding: 4px 8px;
  text-align: center;
  white-space: nowrap;
  align-self: stretch;
}
.result-card .lead {
  font-size: clamp(10px, 3.6vw, 16px);
  font-weight: 600;
  color: var(--color-red);
  text-align: center;
}
.result-card .score {
  font-weight: 700;
  color: var(--color-red);
  line-height: 1;
}
.result-card .score .num { font-size: clamp(28px, 11vw, 44px); }
.result-card .score .unit { font-size: clamp(16px, 7vw, 24px); }
.result-card .detail {
  font-size: clamp(10px, 3.8vw, 14px);
  color: var(--color-primary);
  text-align: center;
}
@media (min-width: 768px) {
  .result-card {
    gap: 16px;
    padding: clamp(12px, 1.5vw, 20px) clamp(10px, 1.5vw, 24px);
  }
  .result-card .name   { font-size: clamp(13px, 1.2vw, 16px); }
  .result-card .badge  { font-size: clamp(14px, 2vw, 22px); padding: clamp(6px, 0.7vw, 10px) clamp(10px, 1.2vw, 22px); }
  .result-card .lead   { font-size: clamp(13px, 1.2vw, 20px); }
  .result-card .score .num  { font-size: clamp(36px, 3.8vw, 60px); }
  .result-card .score .unit { font-size: clamp(22px, 2.4vw, 40px); }
  .result-card .detail { font-size: clamp(12px, 1.1vw, 16px); }
}

/* --- FAQアイテム --- */
.faq-item {
  background: var(--bg-lightblue);
  border-radius: 6px;
  overflow: hidden;
}
/* 質問行 */
.faq_q {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  cursor: pointer;
  user-select: none;
}
.faq-item .q {
  font-weight: 700;
  color: var(--color-text);
  font-size: 24px;
  flex-shrink: 0;
}
.faq-item .text {
  font-weight: 700;
  color: var(--color-text);
  font-size: var(--fs-body);
  flex: 1;
}
/* 開閉アイコン（シェブロン） */
.faq-icon {
  flex-shrink: 0;
  margin-left: auto;
  width: 12px;
  height: 12px;
  border-right: 2px solid var(--color-text);
  border-bottom: 2px solid var(--color-text);
  transform: rotate(45deg);
  transition: transform 0.3s ease;
}
.swell-block-faq__item.open .faq-icon {
  transform: rotate(-135deg);
}
/* 回答パネル */
.faq_a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
  background-color: #fff;
}
.faq-answer-row {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 4px 18px 16px;
}
.faq-answer-cta {
  display: flex;
  justify-content: center;
  padding: 0 18px 20px;
}
.faq-item .a {
  font-weight: 700;
  color: var(--color-blue);
  font-size: 24px;
  flex-shrink: 0;
}
.faq-answer-row .text {
  font-weight: 400;
  color: var(--color-text);
  font-size: var(--fs-body);
  line-height: 1.75;
  flex: 1;
}
@media (min-width: 768px) {
  .faq_q { gap: 32px; padding: 18px 24px; }
  .faq-item .q { font-size: 1.4rem; }
  .faq-item .a { font-size: 1.4rem; }
  .faq-item .text { font-size: 1.25rem; }
  .faq-answer-row { gap: 32px; padding: 12px 24px 24px; }
  .faq-icon { width: 14px; height: 14px; }
}

/* --- 都道府県ボタン --- */
.pref-button {
  position: relative;
  background: var(--color-white);
  border-radius: 4px;
  box-shadow: 0 0 4px rgba(0,0,0,0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  text-decoration: none;
}
.pref-button .name {
  font-size: clamp(16px, 1.1vw, 22px);
  font-weight: 600;
  color: var(--color-primary-deep);
}
/* 右端の山括弧（>）矢印 */
.pref-button::after {
  content: "";
  position: absolute;
  right: 10%;
  top: 50%;
  width: 8px;
  height: 8px;
  border-top: 2px solid var(--color-primary-deep);
  border-right: 2px solid var(--color-primary-deep);
  transform: translateY(-50%) rotate(45deg);
}

@media (min-width: 768px) {
  .pc-only{
    display: block;
  }
  .sp-only{
    display: none;
  }
}
@media (max-width: 767px) {
  .pc-only{
    display: none;
  }
  .sp-only{
    display: block;
  }
}

/* ===================================================================
   mv：メインビジュアル
   =================================================================== */
.mv {
  width: 100%;
}
.mv-img {
  width: 100%;
  height: auto;
  margin: 0 auto;
  margin-bottom: 14px;
}
.mv-underbar{
  background-color: #006dbb;
  padding: 12px;
}
.mv-underbar img {
  max-width: 75%;
  margin: 0 auto;
  display: block;
}
@media (min-width: 768px) {
  .mv-img-wrap {
    width: 100%;
    height: clamp(300px, 40vw, 420px);
    overflow: hidden;
    position: relative;
  }
  .mv-img {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    height: 100%;
    width: auto;
    max-width: none;
    margin-bottom: 0;
  }
}

/* ===================================================================
   campagne-banner：キャンペーンバナー
   =================================================================== */
.campagne-banner {
  width: 100%;
  line-height: 0;
  padding-top: 18px;
}
.campagne-banner img {
  width: 100%;
  height: auto;
  display: block;
}
.campagne-banner__notes {
  list-style: none;
  margin: 8px 0 0;
  padding: 0;
  line-height: 1.6;
}
.campagne-banner__notes li {
  font-size: 13px;
  color: #666;
}

/* ===================================================================
   section-recommended-banner：こんな人にピッタリ
   =================================================================== */
.recommended {
  justify-content: center;
  padding: 40px 0 32px;
}
.recommended__box {
  position: relative;
  background: var(--color-green-light);
  border-radius: 16px;
  width: 100%;
  padding: 30px 16px 16px;
  display: flex;
  flex-direction: column;
}
.recommended__tag-title {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  white-space: nowrap;
  background: var(--color-yellow);
  color: var(--color-primary);
  font-size: clamp(10px, 3.5vw, 20px);
  font-weight: 500;
  border-radius: 50px;
  padding: 5px 16px;
}
.recommended__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.recommended__list li {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  background: var(--color-white);
  color: var(--color-primary);
  font-size: clamp(10px, 3.5vw, 18px);
  font-weight: 500;
  border-radius: 3px;
  padding: 3px 8px;
  white-space: nowrap;
}
.recommended__illust {
  align-self: center;
  width: clamp(80px, 28vw, 110px);
  height: auto;
  margin-bottom: 8px;
}

@media (min-width: 768px) {
  .recommended {
    padding: 80px 0;
  }
  .recommended__box {
    max-width: var(--content-max);
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: clamp(16px, 3vw, 45px);
  }
  .recommended__tag-title {
    font-size: clamp(20px, 2.4vw, 26px);
    padding: 10px clamp(20px, 3vw, 40px);
  }
  .recommended__list {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    flex: 1;
    min-width: 0;
  }
  .recommended__list li {
    font-size: clamp(13px, 1.35vw, 22px);
    border-radius: 8px;
    padding: 8px clamp(10px, 1.2vw, 16px);
    white-space: nowrap;
    width: fit-content;
  }
  .recommended__illust {
    align-self: center;
    width: clamp(80px, 10vw, 150px);
    flex-shrink: 0;
    margin-bottom: 0;
  }
  .campagne-banner{
    padding-top: 32px;
  }
  .campagne-banner__notes {
    display: flex;
    flex-direction: row;
    gap: 10px;
    margin-top: 10px;
  }
  .campagne-banner__notes li{
    font-size: 11px;
  }
}


/* ===================================================================
   section-results：成績アップ事例
   =================================================================== */
.results__band {
  position: relative;
  background: var(--color-cyan);
  text-align: center;
  padding: 28px 0;
}
.results__band::after {
  content: '';
  position: absolute;
  bottom: 1px;
  left: 50%;
  transform: translate(-50%, 100%);
  width: 0;
  height: 0;
  border-left: clamp(24px, 5vw, 42px) solid transparent;
  border-right: clamp(24px, 5vw, 42px) solid transparent;
  border-top: clamp(14px, 3vw, 30px) solid var(--color-cyan);
  z-index: 1;
}
.results__band h2 {
  display: flex;
  flex-direction: column;
  color: var(--color-white);
  font-weight: 700;
  line-height: 1.2;
}
.results__band-sub  { font-size: clamp(16px, 5.5vw, 24px); white-space: nowrap; }
.results__band-main { font-size: clamp(18px, 6.5vw, 28px); color: var(--color-yellow-mark); white-space: nowrap; }

.results__body {
  background: var(--bg-lightblue);
  padding: 40px 0 32px;
}
.results__body .inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.results__catch {
  font-size: clamp(14px, 4.5vw, 28px);
  font-weight: 700;
  color: var(--color-primary);
  white-space: nowrap;
}
.results__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  width: 100%;
}
.results__note {
  font-size: var(--fs-small);
  font-weight: 500;
  color: var(--color-primary);
  text-align: center;
}

/* カード内：head と score の構造 */
.result-card__head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}
.result-card__score {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.result-card__score > *:not(.result-card__arrow) {
  position: relative;
  z-index: 1;
}
.result-card__arrow {
  position: absolute;
  right: 0;
  bottom: 36px;
  width: 46%;
  height: auto;
  z-index: 0;
  height: auto;
}

@media (min-width: 768px) {
  .results__band-sub  { font-size: 45px; }
  .results__band-main { font-size: 50px; }
  .results__body {
    padding: 80px 0;
  }
  .results__body .inner {
    gap: 40px;
  }
  .results__catch { font-size: 40px; }
  .results__cards {
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(12px, 1.5vw, 24px);
  }
  .result-card__arrow { width: 46%; }
  .results__note { font-size: 22px; }
}


/* ===================================================================
   section-points：3つのポイント（共通）
   =================================================================== */
.points {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 40px var(--space-gutter);
}
.points__list {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 100%;
  max-width: var(--content-max);
}

/* --- point-card 共通（白カード＋シアン枠） --- */
.point-card {
  position: relative;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.5), rgba(255, 255, 255, 0.5)),
    url("../images/summer/point_back.webp");
  border: 1px solid var(--color-cyan);
  border-radius: 8px;
  margin-top: 36px;
  padding: 64px 16px 24px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.08);
}
.point-card__badge {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
  width: clamp(100px, 15vw, 162px);
  height: auto;
}
.point-card__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}
.point-card__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding-bottom: 8px;
  padding-top: clamp(1px, 1vw, 12px);
}
.point-card__heading h3 {
  font-size: clamp(23px, 5.7vw, 34px);
  font-weight: 800;
  color: var(--color-cyan);
  text-align: center;
  line-height: 1.4;
}
.point-card__heading.point2 h3{
    font-size: clamp(22px, 5.7vw, 34px);
}
.point-card__underline {
  display: block;
  width: 160px;
  height: 3px;
  background: var(--color-yellow);
}
.point-card__body {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}

/* --- Point 01 本文：2カラム制御 --- */
.point01__left {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
/* SP：例（右カラム）をリードの直後・説明文の前に表示 */
.point01__body { display: flex; flex-direction: column; }
.point01__left  { order: 1; display: contents; }   /* SPでは中身をフラット展開 */
.point01__right { order: 0; }

/* SPで「リード→例→説明文→強調」の順にするための個別order */
.point01__lead     { order: 0; }
.point01__right    { order: 1; }
.point01__desc     { order: 2; }
.point01__reason   { order: 3; }
.point01__body { gap: 32px; }

.point01__reason {
  border-radius: 8px;
  padding: 16px 20px 16px 32px;
  background: #EAF8FD;
}
.point01__reason-title {
  font-size: clamp(18px, 4vw, 22px);
  font-weight: 700;
  color: var(--color-primary);
  padding-bottom: 10px;
}
.point01__reason-lead {
  font-size: clamp(13px, 3.5vw, 15px);
  color: var(--color-text);
}
.point01__reason-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.point01__reason-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: clamp(14px, 4vw, 18px);
  font-weight: 500;
  color: var(--color-text);
}
.point01__reason-list li::before {
  content: "✓";
  color: var(--color-cyan);
  font-size: 1.1em;
  flex-shrink: 0;
}

.point01__lead {
  display: flex;
  flex-direction: column;
  --lead-base: clamp(14px, 5.5vw, 36px);
}
.point01__lead-main {
  text-align: center;
  font-size: calc(var(--lead-base) * 0.85);
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1.8;
  white-space: nowrap;
}
.point01__lead-main .hl {
  background: #FFF36D;
  color: var(--color-primary);
  font-size: var(--lead-base);
  font-weight: 700;
  line-height: 1;
  display: inline-block;
}
.point01__nuance {
  font-size: calc(var(--lead-base) * 0.75);
  font-weight: 700;
  color: var(--color-primary);
}
.point01__nuance strong {
  font-size: var(--lead-base);
  font-weight: 700;
}

.point01__example {
  background: var(--color-white);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 18px 20px 32px 16px;
  box-shadow: 0 0px 12px rgba(0, 0, 0, 0.06);
  border-radius: 4px;
  border: 1px solid rgba(80, 140, 200, 0.18);
}
.point01__example-title {
  font-size: clamp(16px, 5vw, 22px);
  font-weight: 600;
  color: var(--color-text);
  text-align: center;
  line-height: 1.5;
}
.point01__example-sub {
  font-size: 0.75em;
  font-weight: 400;
}
.point01__flow {
  display: flex;
  flex-direction: column;
  gap: 20px;
  width: 100%;
}
.point01__row {
  display: flex;
  gap: 8px;
  align-items: flex-start;
}
.point01__grade {
  flex-shrink: 0;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  border: 1px solid var(--color-cyan);
  background: var(--color-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-cyan-mid);
  text-align: center;
  line-height: 1.3;
}
.point01__step {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding-bottom: 27px;
  flex: 1;
  min-width: 0;
}
.point01__row:last-child .point01__step { padding-bottom: 0; }
.point01__label {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  border-radius: 10px;
  padding: 8px 8px;
  font-size: clamp(16px, 4.7vw, 24px);
  color: var(--color-white);
}
.point01__label--cyanlt { background: var(--color-cyan-light); font-weight: 500; }
.point01__label--cyan   { background: var(--color-cyan); font-weight: 500; }
.point01__label--blue   { background: var(--color-blue-alt); font-weight: 500; }
.point01__unit {
  font-size: clamp(16px, 5vw, 22px);
  font-weight: 500;
  color: var(--color-text);
  text-align: center;
  line-height: 1.8;
}
.point01__arrow {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0; height: 0;
  border-style: solid;
  border-width: 16px 24px 0 24px;
  border-color: var(--color-cyan) transparent transparent transparent;
}

.point01__desc {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.8;
  background-color: #fff;
}
.point01__desc-hl {
  color: #D86B00;
  font-weight: 700;
}

/* ===================================================================
   PC（768px〜）
   =================================================================== */
@media (min-width: 768px) {
  .points { gap: 60px; padding: 80px var(--space-gutter); }
  .points__list { gap: 60px; }

  .point-card {
    --_badge-sz: clamp(80px, 10vw, 148px);
    margin-top: 0;
    padding: 40px clamp(32px, 4vw, 60px) 60px;
    padding-top: clamp(24px, 2.7vw, 38px);
  }
  .point-card__badge {
    width: clamp(80px, 14vw, 162px);
    top: 0;
    left: 6%;
    transform: translateY(-25%);
  }
  .point-card__inner { gap: 0; align-items: stretch; }

  .point-card__heading {
    flex-direction: column;
    align-items: flex-start;
    align-self: flex-start;   /* heading をテキスト幅に縮小 */
    gap: 8px;
    margin-bottom: 40px;
    padding-bottom: 0;
    padding-left: calc(6% + clamp(80px, 14vw, 162px) + 16px);
  }
  .point-card__heading h3 { text-align: left; font-size: clamp(24px, 2.7vw, 38px); }
  .point-card__heading h3 br { display: none; }
  .point-card__underline { align-self: stretch; width: auto; height: 5px; background: var(--color-yellow); }
  .point-card__heading.point2 h3{
      font-size: clamp(24px, 2.7vw, 38px);
  }
  /* PC：左右2カラム。display:contentsを解除して実カラム化 */
  .point01__body {
    flex-direction: row;
    gap: clamp(20px, 3vw, 80px);
    align-items: flex-start;
    padding-top: 24px;
  }
  .point01__left {
    display: flex;
    flex-direction: column;
    gap: 42px;
    flex: 0 0 clamp(280px, 55%, 620px);
    order: 0;
  }
  .point01__right {
    order: 1;
    flex: 1;
    min-width: 0;
  }
  /* 左カラム内の要素は通常フローに戻す（orderリセット） */
  .point01__lead, .point01__desc, .point01__reason { order: 0; }

  .point01__lead {
    --lead-base: clamp(20px, 3.3vw, 42px);
  }
  .point01__lead-main {
    text-align: left;
  }

  .point01__flow { display: grid; grid-template-columns: auto 1fr; gap: 20px 8px; align-items: start; }
  .point01__row { display: contents; }

  .point01__example-title { font-size: clamp(13px, 1.6vw, 22px); }
  .point01__label { width: 100%; font-size: clamp(14px, 1.8vw, 24px); }
  .point01__unit { font-size: clamp(14px, 1.8vw, 22px); }
  .point01__desc { font-size: clamp(14px, 1.6vw, 20px); }
  .point01__lead-main .hl{ padding: 8px 16px; }
}

/* --- Point 02 本文：2カラム制御 --- */
.point02__body { display: flex; flex-direction: column; gap: 24px; }
/* SP：左カラムをフラット展開し、order で「リード→説明→タグ→例」順に */
.point02__left  { display: contents; }
.point02__lead     { order: 0; }
.point02__desc     { order: 1; }
.point02__tags     { order: 2; }
.point02__right    { order: 3; padding-top: 16px; }

/* リード */
.point02__lead {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.point02__lead-line1 {
  display: flex;
  align-items: flex-end;
  gap: 6px;
}
.point02__lead-catchbox {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
}
.point02__lead-img { width: 175px; height: auto; padding-bottom: 8px; }
.point02__lead-main {
  background: #FFF36D;
  color: var(--color-primary);
  font-size: 17px;
  font-weight: 700;
  padding: 8px 12px;
  line-height: 1;
  display: inline-block;
}
.point02__de { font-size: 15px; font-weight: 700; color: var(--color-primary); }
.point02__lead-sub {
  font-weight: 700;
  color: var(--color-primary);
}
.point02__lead-sub .lg { font-size: 22px; }
.point02__lead-sub .sm { font-size: 18px; }

/* 説明文 */
.point02__desc {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.8;
  background-color: #fff;
}

/* タグ群 */
.point02__tags {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(8px, 3vw, 16px);
  width: 100%;
}
.point02__tags li {
  border-radius: 6px;
  padding: 8px clamp(4px, 2vw, 16px);
  font-size: clamp(12px, 3vw, 16px);
  color: #fff;
  font-weight: 600;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  background-color: var(--color-cyan);
}

/* 例 */
.point02__example {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  width: 100%;
}
.point02__example-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text);
  text-align: center;
}
.point02__example-imgs {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}
.point02__example-imgs img { width: 100%; height: auto; }
.point02__example-note {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.8;
  padding: 20px 8px;
  background: #fff;
}
.point02__example-note .em { color: #D86B00; }

/* 画像2枚横並び（560px〜）：各画像が約240px確保できるタイミング */
@media (min-width: 560px) {
  .point02__example-imgs { flex-direction: row; gap: 8px; }
  .point02__example-imgs img { flex: 1 1 0; min-width: 0; width: 0; height: auto; }
}

/* PC：フォント・コンテンツサイズ（768px〜） */
@media (min-width: 768px) {
  /* 1カラム時の順序：lead → desc → tags → 例(right) */
  .point02__desc  { order: 1; }
  .point02__tags  { order: 2; }
  .point02__right { order: 3; }

  .point02__lead { align-items: center; }
  .point02__lead-img { width: clamp(120px, 18vw, 240px); }
  .point02__lead-main { font-size: clamp(17px, 2.8vw, 36px); }
  .point02__de { font-size: clamp(15px, 2.5vw, 32px); }
  .point02__lead-sub .lg { font-size: clamp(20px, 3.0vw, 36px); }
  .point02__lead-sub .sm { font-size: clamp(15px, 2.2vw, 28px); }
  .point02__desc { font-size: clamp(14px, 1.6vw, 22px); }
  .point02__tags { max-width: clamp(280px, 42vw, 528px); gap: clamp(8px, 1.5vw, 16px); margin: 0 auto; }
  .point02__tags li { font-size: clamp(12px, 1.5vw, 20px); padding: clamp(6px, 0.8vw, 10px) clamp(8px, 1.2vw, 16px); white-space: nowrap; }
  .point02__example-title { font-size: clamp(14px, 2vw, 28px); }
  .point02__example-imgs { flex-direction: row; gap: 8px; }
  .point02__example-imgs img { flex: 1 1 0; min-width: 0; width: 0; height: auto; }
  .point02__example-note { font-size: clamp(14px, 1.6vw, 22px); padding-top: 20px;}

  .point02__body,
  .point03__body{
    padding-top: 24px;
  }
}
@media (min-width: 1100px) {
  .point02__example-title { font-size: clamp(14px, 1.6vw, 22px); }
}

/* PC：2カラムレイアウト（1100px〜） */
@media (min-width: 1100px) {
  .point02__body { flex-direction: row; gap: clamp(20px, 3vw, 40px); align-items: flex-start; }
  .point02__left {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(20px, 3vw, 42px);
    flex: 0 0 clamp(280px, 55%, 620px);
    order: 0;
  }
  .point02__right { order: 1; flex: 1; min-width: 0; display: flex; flex-direction: column; padding-top: 0; }
  .point02__lead, .point02__desc, .point02__tags { order: 0; }
  .point02__lead { align-items: flex-start; }
  .point02__tags { margin: 0; }
}


/* --- Point 03 --- */

.point03__body { display: flex; flex-direction: column; gap: 24px; }

/* 上段：日付（全幅）＋ 時間割＋画像（横並び） */
.point03__schedule-area {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: 40px;
}
.point03__date-block {
  flex: 0 0 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.point03__date-text {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}
.point03__date-visual {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.point03__date-img { width: 100%; height: auto; max-width: 160px; }
.point03__date-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding-bottom: 8px;
}
.point03__date-label {
  color: #fff;
  background: var(--color-cyan);
  font-size: 16px;
  font-weight: 700;
  padding: 1px 12px;
  border-radius: 3px;
  white-space: nowrap;
  flex-shrink: 0;
}
.point03__date {
  font-weight: 700;
  color: var(--color-blue-deep);
  white-space: nowrap;
}
.point03__date .lg { font-size: 22px; }
.point03__date .sm { font-size: 14px; }
.point03__date-tag {
  border: 2px solid var(--color-cyan);
  color: var(--color-cyan);
  font-size: 15px;
  font-weight: 600;
  padding: 6px 18px;
  background-color: #fff;
}
.point03__date-lead {
  font-size: clamp(19px, 4.2vw, 26px);
  font-weight: 700;
  color: var(--color-primary);
  text-align: center;
}
.point03__date-lead .em-bg {
  background: #FFF36D;
  padding: 8px 12px;
  display: inline-block;
  line-height: 1;
}
.point03__date-lead .de {
  font-size: 0.75em;
}
.point03__date-desc {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.6;
  background: #fff;
}
.point03__date-desc .em { color: var(--color-orange); font-weight: 700; }


/* 時間割表：1カラム時は行全幅まで広がる */
.point03__timetable { flex: 1 0 190px; width: auto; }
.point03__timetable td { white-space: nowrap; background-color: #fff; }
.point03__timetable h4 {
  font-size: 18px;
  font-weight: 700;
  color: var(--color-text);
  text-align: center;
  margin-bottom: 10px;
}
.point03__timetable table {
  border-collapse: collapse;
  width: 100%;
  margin: 0 auto;
}
.point03__timetable th,
.point03__timetable td {
  border: 1px solid var(--color-primary);
  padding: 10px;
  font-size: clamp(14px, 3.5vw, 24px);
  font-weight: 500;
  color: var(--color-primary);
  text-align: center;
}
.point03__timetable th {
  background: var(--bg-lightblue);
  width: 94px;
  white-space: nowrap;
}

/* 受講例 */
.point03__example {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  padding: 24px 0;
}
.point03__example-head {
  position: relative;
  width: 100%;
  height: 42px;
}
.point03__example-headbg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.point03__example-headtext {
  display: block;
  font-size: 22px;
  font-weight: 500;
  color: var(--color-white);
  background-color: var(--color-cyan);
  padding: 0 36px 0 20px;
  height: 42px;
  line-height: 42px;
  width: min(300px, 100%);
  text-align: center;
  clip-path: polygon(0 0, calc(100% - 21px) 0, 100% 50%, calc(100% - 21px) 100%, 0 100%);
  filter: drop-shadow(3px 3px 0 #F5E428);
}
.point03__person {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}
.point03__person-photo {
  background: var(--color-green-tag);
  border-radius: 18px;
  padding: 3px;
  width: 160px;
}
.point03__person-photo img {
  width: 100%;
  height: auto;
  display: block;
}
.point03__person-name {
  background: var(--color-white);
  border-radius: 0 0 16px 16px;
  padding: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--color-primary);
  text-align: center;
  line-height: 1.3;
}
.point03__person-text {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}
.point03__person-lead {
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 600;
  color: var(--color-cyan);
  line-height: 1.45;
}
.point03__person-body {
  font-size: 16px;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.9;
  background: #fff;
}
p.point03__example-catch {
  position: relative;
  font-size: clamp(15px, 2vw, 22px);
  font-weight: 700;
  color: var(--color-cyan);
  background: var(--color-white);
  border: 2px solid var(--color-cyan);
  padding: 12px 20px;
  border-radius: 6px;
  text-align: center;
  line-height: 1.5;
  margin-bottom: 18px;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.point03__example-catch::before {
  content: "";
  position: absolute;
  bottom: -9px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 14px;
  height: 14px;
  background: var(--color-white);
  border-right: 2px solid var(--color-cyan);
  border-bottom: 2px solid var(--color-cyan);
}
.point03__example-catch::after {
  display: none;
}

/* 理解度確認テスト */
.point03__test {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin-top: -20px;
  background: var(--bg-lightblue);
  border-radius: 12px;
  padding: 24px 24px;
}
.point03__test-text {
  display: flex;
  flex-direction: column;
  gap: 32px;
}
.point03__test-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--color-cyan);
  line-height: 1.4;
}
.point03__test-title::before {
  content: "★";
  margin-right: 4px;
}
.point03__test-desc {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.5;
}
.point03__test-note {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text);
  line-height: 1.4;
}
.point03__test-img {
  width: 100%;
  height: auto;
  max-width: 400px;
  margin: 0 auto;
  box-shadow: 0 0px 10px -2px rgba(0, 0, 0, 0.5);
}

/* PC */
@media (min-width: 768px) {
  .point03__body { gap: 40px; }

  /* 上段：日付（左）＋時間割（中）＋生徒写真（右）＝3カラム固定 */
  .point03__schedule-area {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 48px;
  }
  .point03__date-block { flex: 1 0 280px; align-items: flex-start; gap: 42px; }
  .point03__date-tags { margin: 0; max-width: none; }
  .point03__date-visual .point03__date-img { width: 100%; max-width: 240px;}
  .point03__date { text-align: left; }
  .point03__date .lg { font-size: clamp(20px, 2.6vw, 34px); }
  .point03__date .sm { font-size: clamp(13px, 1.6vw, 22px); }
  .point03__date-tag { font-size: clamp(13px, 1.5vw, 20px);}
  .point03__date-lead { font-size: clamp(20px, 2.4vw, 34px); text-align: left; }
  .point03__date-desc { font-size: clamp(14px, 1.6vw, 22px); }
  .point03__person-body { font-size: clamp(14px, 1.6vw, 22px); }
  .point03__test-desc { font-size: clamp(14px, 1.6vw, 22px); }
  .point03__test-note { font-size: clamp(14px, 1.6vw, 18px); }
  .point03__timetable { flex: 1 0 280px; }
  .point03__timetable h4 { font-size: clamp(16px, 2vw, 26px); }
  .point03__timetable th, .point03__timetable td { font-size: clamp(14px, 2vw, 26px); }
  .point03__timetable th { width: clamp(94px, 8vw, 140px); }
  .point03__timetable td { white-space: nowrap; }

  .point03__person { flex-direction: row; align-items: center; gap: 24px; }
  .point03__person-photo { flex-shrink: 0; width: 220px; }
  .point03__person-lead { font-size: 28px; padding-top: 8px; margin-bottom: 2px;}


  .point03__test {
    display: grid;
    grid-template-columns: 1fr clamp(160px, 28vw, 400px);
    grid-template-rows: auto auto;
    grid-template-areas: "text img" "note img";
    column-gap: 40px;
    row-gap: 16px;
    margin-top: -20px;
    padding: 32px 64px;
  }
  .point03__test-text { grid-area: text; }
  .point03__test-img { grid-area: img; align-self: start; width: 100%; max-width: none; margin: 0; }
  .point03__test-note { grid-area: note; align-self: start; }
  .point03__test-title { font-size: clamp(22px, 3vw, 30px); }
  p.point03__example-catch{ margin-left: 0; margin-right: 0;}
  .point03__date-text { gap: 42px; }
  .point03__date-label { font-size: 18px; }
}


/* --- Point 03：7月の受講例 --- */
.point03__july {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.point03__july-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  margin-bottom: 8px;
}
.point03__july-frame {
  width: 100%;
  max-width: 900px;
  background: var(--color-white);
  border: 2px solid var(--color-primary);
  padding: 30px 10px 20px;
  border-radius: 24px;
}
.point03__july-title {
  color: var(--color-primary);
  font-weight: 700;
  white-space: nowrap;
}
.point03__july-title .lg { font-size: 24px; }
.point03__july-title .sm { font-size: 20px; }
.point03__july-course {
  color: var(--color-primary);
  font-weight: 500;
  white-space: nowrap;
}
.point03__july-course .lg { font-size: 20px; }
.point03__july-course .sm { font-size: 16px; }
.point03__july-detail {
  background: var(--color-yellow-light);
  border: 2px solid var(--color-primary);
  color: var(--color-primary);
  font-size: 18px;
  font-weight: 500;
  padding: 6px 12px;
  white-space: nowrap;
}
.point03__july-suffix {
  color: var(--color-primary);
  font-size: 18px;
  font-weight: 500;
  white-space: nowrap;
}
.point03__july-img {
  width: 100%;
  height: auto;
  display: block;
}

@media (min-width: 768px) {
  .point03__july-heading {
    flex-wrap: nowrap;
    gap: 24px;
    padding: 0 24px;
    background: var(--color-white);
    margin-bottom: -26px;
    position: relative;
    z-index: 2;
  }
  .point03__july-frame {
    padding: 48px 32px 32px;
  }
  .point03__july-title .lg { font-size: clamp(20px, 2.4vw, 30px); }
  .point03__july-title .sm { font-size: clamp(16px, 1.8vw, 24px); }
  .point03__july-course .lg { font-size: clamp(18px, 2vw, 26px); }
  .point03__july-course .sm { font-size: clamp(14px, 1.6vw, 20px); }
  .point03__july-detail { font-size: clamp(14px, 1.6vw, 20px); padding: 6px 14px; }
  .point03__july-suffix { font-size: clamp(14px, 1.6vw, 20px); }
}



/* ===================================================================
   section-pricing：授業料金
   =================================================================== */
.pricing {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  margin-top: 40px;
  margin-bottom: 40px;
}
.pricing__hero { width: 100%; height: auto; }

/* SPでは bottom は縦積み */
.pricing__bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  width: 100%;
  padding-top: 16px;
}
.pricing__desc {
  font-size: 16px;
  color: var(--color-text);
  line-height: 1.75;
  padding: 0 8px;
}
.pricing__table-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100%;
}
.pricing__table-title {
  font-size: clamp(18px, 4vw, 26px);
  font-weight: 600;
  color: var(--color-primary);
  text-align: center;
}
.pricing__table {
  border-collapse: collapse;
  width: 100%;
}
.pricing__table th,
.pricing__table td {
  border: 1px solid #ddd;
  height: 60px;
  padding: 10px;
  font-size: 16px;
  font-weight: 500;
  color: var(--color-primary);
  text-align: center;
  white-space: nowrap;
}
.pricing__table thead th {
  background: var(--color-white);
  border-bottom: none;
}
.pricing__table tbody th {
  background: var(--bg-table-head);
  width: clamp(70px, 18vw, 120px);
}

@media (min-width: 768px) {
  .pricing { gap: 60px; padding: 80px var(--space-gutter); }
  .pricing__inner {
    max-width: var(--content-max);
    gap: 39px;
  }
  /* PC：下段を横並び */
  .pricing__desc { font-size: clamp(14px, 1.6vw, 22px); }
  .pricing__table-title { clamp(18px, 4vw, 26px) }
  .pricing__table th, .pricing__table td { font-size: 18px; padding: 10px 20px; }
  .pricing__table th { width: clamp(100px, 10vw, 160px); }
  .pricing__bottom { gap: 64px; }
}


/* ===================================================================
   section-testimonials：受講者の声
   =================================================================== */
.testimonials {
  background: var(--bg-lightblue);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 27px;
  padding: 40px 0 32px;
}
.testimonials__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 27px;
  width: 100%;
}
.testimonials__lead {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  padding-top: 32px; 
}
.testimonials__lead-text {
  font-size:  clamp(16px, 2vw, 22px);
  font-weight: 700;
  color: var(--color-blue);
}
.testimonials__lead-img { width: 140px; height: auto;}

/* カード群 */
.testimonials__cards {
  display: flex;
  flex-direction: column;
  gap: 40px;
  width: 100%;
  padding-left: 60px;       /* 左にはみ出すイラスト用の余白 */
}

/* --- 声カード --- */
.voice-card {
  position: relative;
  background: var(--color-white);
  border-radius: 32px;
  filter: drop-shadow(0 2px 1px rgba(0,0,0,0.08));
  padding: 24px 24px 24px 70px;
}
.voice-card__illust {
  position: absolute;
  left: -60px;
  top: 50%;
  transform: translateY(-50%);
  width: 110px;
}
.voice-card__illust img { width: 100%; height: auto; display: block; }
.voice-card__text {
  font-size: 16px;
  color: var(--color-text);
  line-height: 2.4;
}
.voice-card__text .em { color: var(--color-red-text); }

/* 締めコメント */
.testimonials__closing {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 100%;
  padding-top: 32px;
}
.testimonials__closing-icon { width: 60px; height: 60px; }
.testimonials__closing-text {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-blue);
  line-height: 1.6;
  text-align: center;
}

@media (min-width: 768px) {
  .testimonials { gap: 60px; padding: 80px var(--space-gutter); }
  .testimonials__inner { max-width: var(--content-max); gap: 40px; }
  .testimonials__lead-text { font-size:  clamp(32px, 2vw, 40px); }
  .testimonials__lead-img { width: 188px; }

  /* PC：カードを2列グリッド */
  .testimonials__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 32px clamp(70px, 8vw, 110px);
    padding-left: clamp(50px, 6vw, 80px);
  }
  .voice-card {
    width: 100%;
    padding: clamp(20px, 2vw, 40px) clamp(16px, 1.8vw, 32px) clamp(20px, 2vw, 40px) clamp(60px, 7vw, 100px);
  }
  .voice-card__illust {
    left: calc(-1 * clamp(50px, 6vw, 80px));
    width: clamp(90px, 10vw, 160px);
  }
  .voice-card__text { font-size: clamp(14px, 1.6vw, 22px); line-height: 2; }

  .testimonials__closing { flex-direction: row; gap: 32px; }
  .testimonials__closing-icon { width: 80px; height: 80px; }
  .testimonials__closing-text { font-size: 24px; text-align: left; }
}

/* ナロー SP（～479px）：イラストをカード上辺に重ねてテキスト幅を確保 */
@media (max-width: 479px) {
  .testimonials__cards {
    padding-left: 0;
    padding-top: 44px;
    gap: 60px;
  }
  .voice-card {
    padding: 50px 16px 20px 16px;
  }
  .voice-card__illust {
    left: 50%;
    top: 0;
    transform: translateX(-50%) translateY(-50%);
    width: 68px;
  }
}



/* ===================================================================
   section-faq：よくある質問
   =================================================================== */
.faq {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 40px var(--space-gutter);
}
.faq__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  max-width: 1100px;
}
/* Step 1 の .faq-item を流用。SP用に q と text の比率を微調整 */
.faq-item .text { flex: 1; }

@media (min-width: 768px) {
  .faq { gap: 60px; padding: 80px var(--space-gutter); }
  .faq__list { gap: 32px; }
}



/* ===================================================================
   section-find-school：お近くの教室を探す
   =================================================================== */
.find-school {
  background: var(--bg-mint);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  padding: 40px var(--space-gutter);
}
.find-school__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 100%;
  max-width: 952px;
}
.find-school__lead {
  font-size: var(--fs-body);
  font-weight: 500;
  color: var(--color-text);
  text-align: center;
  line-height: 1.7;
}
.find-school__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  width: 100%;
}
/* .pref-button は Step 1 で定義済み */

@media (min-width: 768px) {
  .find-school { gap: 32px; padding: 80px var(--space-gutter); }
  .find-school__inner { max-width: 952px; gap: 32px; }
  .find-school__lead { font-size: 24px; }
  .find-school__grid { gap: 32px 24px; }
  .pref-button { height: 77.5px; }
  .pref-button .name { font-size: 22px; }
}

/* ===================================================================
   cta-banner（最終）：PCで高さ252px相当（padding 60px）
   =================================================================== */
.cta-banner--final {
  padding-top: 32px;
  padding-bottom: 32px;
}
/* 最終バナーはラベル文字が緑（他は黒） */
.cta-label--green { color: var(--color-primary); }

/* ===================================================================
   overview：受講概要
   =================================================================== */
.overview {
  padding: 40px 0;
}
.overview .inner {
  margin-top: 32px;
}
.overview__table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #ddd;
}
.overview__table td ul {
  margin: 0;
  padding-left: 0;
  list-style: none;
}
.overview__table td ul li::before {
  content: "◎";
  margin-right: 4px;
  color: var(--color-primary);
}
.overview__table th,
.overview__table td {
  padding: 14px 16px;
  font-size: clamp(13px, 3.5vw, 16px);
  line-height: 1.6;
  border: 1px solid #ddd;
  vertical-align: top;
  text-align: left;
}
.overview__table th {
  width: 7em;
  font-weight: 700;
  color: var(--color-primary);
  white-space: nowrap;
  background: var(--bg-lightblue);
  vertical-align: middle;
}
@media (min-width: 768px) {
  .overview {
    padding: 80px 0;
  }
  .overview__table th {
    width: clamp(10em, 15vw, 16em);
  }
}
.overview__subjects {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.overview__subjects > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.overview__subjects dt {
  font-weight: 700;
  color: var(--color-primary);
  white-space: nowrap;
}
.overview__subjects dd {
  margin: 0;
}
@media (min-width: 768px) {
  .overview__subjects > div {
    flex-direction: row;
    align-items: baseline;
    gap: 12px;
  }
  .overview__subjects dt {
    min-width: 4em;
  }
}
.overview__courses {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.overview__courses > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.overview__courses dt {
  font-weight: 700;
  color: var(--color-primary);
  white-space: nowrap;
  min-width: 4em;
  padding-top: 2px;
}
.overview__courses dd {
  margin: 0;
}
.overview__courses-catch {
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 4px;
}
.overview__courses ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.overview__courses ul li::before {
  content: "◎";
  margin-right: 4px;
  color: var(--color-primary);
}

/* ===================================================================
   video-intro：動画紹介
   =================================================================== */
.video-intro {
  padding: 40px 0 32px;
  background-color: var(--bg-mint);
}
@media (min-width: 768px) {
  .video-intro {
    padding: 80px 0;
  }
}
.video-intro .inner {
  padding-top: 32px;
}
.video-intro__wrap {
  position: relative;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}
.video-intro__wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media (min-width: 768px) {
  .cta-banner--final {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
