/* ==========================================================================
   介護美容研究所 LP — 統合スタイルシート
   ========================================================================== */

/* --------------------------------------------------------------------------
   カラー変数
   -------------------------------------------------------------------------- */
:root {
  --c-pink:         #fa52af;
  --c-pink-deep:    #f14a91;
  --c-pink-light:   #fcebf3;
  --c-pink-pale:    #ffcfe5;
  --c-orange:       #ff8b3d;
  --c-orange-pale:  #ffebdd;
  --c-green:        #1cbd90;
  --c-green-pale:   #def2ec;
  --c-teal:         #37aea5;
  --c-navy:         #2e324b;
  --c-navy-deep:    #090533;
  --c-navy-mid:     #37465a;
  --c-blue-gray:    #d0d8ea;
  --c-storm-gray:   #6e728d;
  --c-gray:         #777;
  --c-gray-light:   #6b6b6b;
  --c-whisper:      #f8f7fa;
  --c-white:        #fff;
}

/* --------------------------------------------------------------------------
   リセット & ベース
   -------------------------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.lp-wrap {
  font-family: 'Noto Sans JP', sans-serif;
  background: var(--c-whisper);
  color: var(--c-navy-deep);
  font-size: 15px;
  line-height: 1.75;
  letter-spacing: 0.05em;
}

img {
  display: block;
  max-width: 100%;
}

/* スクリーンリーダー専用テキスト */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* --------------------------------------------------------------------------
   LP ラッパー (390px 固定幅)
   -------------------------------------------------------------------------- */
.lp {
  width: 100%;
  max-width: 450px;
  margin: 0 auto;
  background: var(--c-white);
  overflow: hidden;
}

/* --------------------------------------------------------------------------
   共通: 本文テキスト
   -------------------------------------------------------------------------- */
.body-text {
  font-weight: 400;
  font-size: 14.5px;
  line-height: 26.33px;
  color: var(--c-navy-deep);
  width: 100%;
}
.body-text strong { font-weight: 700; }
.body-text--bold  { font-weight: 700; }


/* ==========================================================================
   ★ FV ヒーロー: 未経験から始める、介護美容という副業
   ========================================================================== */

/* ナビバー: ロゴ + CTA (高さ59px) */
.sec-fv-hero {
  width: 100%;
  background: var(--c-white);
  overflow: hidden;
}

.fv-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 4px 8px;
  min-height: 59px;
}

.fv-nav__logo {
  display: flex;
  align-items: center;
  padding: 5px;
  flex: 1 1 auto;
  min-width: 100px;
  max-width: 200px;
}
.fv-nav__logo img {
  width: auto;
  max-width: 100%;
  height: 50px;
  object-fit: contain;
}

.fv-nav__cta {
  flex: 0 0 auto;
  overflow: hidden;
}
.fv-nav__cta img {
  width: auto;
  height: 57px;
  object-fit: contain;
}

/* ヒーロー画像 */
.fv-hero {
  width: 100%;
}
.fv-hero img {
  width: 100%;
  height: auto;
  display: block;
}


/* ==========================================================================
   ★ Toha: 介護美容研究所とは？
   ========================================================================== */

/* タイトルエリア: ブルーグレー帯(35px) + タイトル画像(192px) の重なり */
.sec-toha__title-wrap {
  display: grid;
  grid-template: 222px / 1fr;
  width: 100%;
}

.sec-toha__bg-strip {
  grid-area: 1/1;
  align-self: start;
  height: 40px;
  background: var(--c-blue-gray);
}

.sec-toha__title-img {
  grid-area: 1/1;
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: top;
}

/* メインコンテンツ: white bg, padding-bottom:40px, gap:21px */
.sec-toha__body {
  background: var(--c-white);
  padding: 16px 24px 40px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
}

/* 見出し */
.sec-toha__heading {
  font-weight: 700;
  font-size: 20.6px;
  line-height: 30.23px;
  color: #f14a91;
  text-align: center;
  white-space: nowrap;
}

/* ロゴ + バッジ横並び */
.sec-toha__content {
  display: flex;
  flex-direction: column;
  gap: 13px;
  align-items: center;
  width: 100%;
}

.sec-toha__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.sec-toha__logo {
  width: 186.256px;
  height: 36.477px;
  flex-shrink: 0;
}
.sec-toha__logo img {
  width: 100%;
  object-fit: contain;
}

.sec-toha__badge {
  width: auto;
  height: 34px;
  overflow: hidden;
}
.sec-toha__badge img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* 3枚の実習写真 */
.sec-toha__photos {
  width: 100%;
  overflow: hidden;
}
.sec-toha__photos img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* ポイント3点カード: bg #fcebf3, padding 4.726px */
.sec-toha__point-wrap {
  background: var(--c-pink-light);
  padding: 0 16px 6px;
  width: 100%;
  flex-shrink: 0;
}

.sec-toha__point-img {
  object-fit: cover;
}


/* ==========================================================================
   ★ Skills: ケアビューティストに求められる3つの要素
   ========================================================================== */

/* タイトルエリア: ピンク帯(36px, top:158px) + タイトル画像(194px) */
.sec-skills__title-wrap {
  display: grid;
  grid-template: 222px / 1fr;
  width: 100%;
}

.sec-skills__pink-strip {
  grid-area: 1/1;
  align-self: end;
  height: 70px;
  background: #feddd4;
}

.sec-skills__title-img {
  grid-area: 1/1;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* メインコンテンツ */
.sec-skills__body {
  background: #fedfd6;
  width: 100%;
  padding: 24px 24px 40px;
}

.sec-skills__inner {
  display: flex;
  flex-direction: column;
  gap: 36px;
  align-items: center;
}

/* 3スキル: 上段1個 + 下段2個 */
.sec-skills__grid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 100%;
}

.sec-skills__item--top {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.sec-skills__bottom-row {
  display: flex;
  justify-content: space-around;
  gap: 16px;
  width: 100%;
}

.sec-skills__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

/* 円形写真 + チェックバッジ (CSS Gridで重ね) */
.sec-skills__circle-wrap {
  display: grid;
  grid-template: max-content / max-content;
}

.sec-skills__circle-img {
  grid-area: 1/1;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.sec-skills__check {
  grid-area: 1/1;
  align-self: start;
  justify-self: start;
  margin-left: 111px;
  margin-top: 6px;
  width: 35px;
  height: 35px;
}

/* ラベルテキスト */
.sec-skills__label {
  font-weight: 700;
  font-size: 16.4px;
  line-height: 21.45px;
  color: #f6645e;
  text-align: center;
}

/* 説明カード */
.sec-skills__card {
  background: var(--c-white);
  border-radius: 20px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sec-skills__card-text {
  font-size: 14px;
  line-height: 23.4px;
  color: var(--c-navy-deep);
  font-weight: 400;
}

.sec-skills__accent {
  font-weight: 700;
  color: #f6645e;
}

/* フッター CTA バー (h:145px, bg:#d0d8ea) */
.sec-skills__cta-bar {
  background: var(--c-blue-gray);
  width: 100%;
  height: 145px;
  padding: 0 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sec-skills__cta-bar img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}


/* ==========================================================================
   ① FV: ファーストビュー
   ========================================================================== */
.sec-fv {
  background: var(--c-white);
  padding: 60px 24px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.sec-fv__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  width: 100%;
}

/* タイトル画像 */
.sec-fv__title {
  width: 100%;
  height: 86.77px;
}
.sec-fv__title img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* メッセージテキスト */
.sec-fv__messages {
  display: flex;
  flex-direction: column;
  gap: 21px;
  align-items: center;
  text-align: center;
  width: 100%;
}

.sec-fv__msg-sub {
  font-weight: 400;
  font-size: 15px;
  line-height: 25px;
  color: var(--c-navy-deep);
  letter-spacing: 0.6px;
}

.sec-fv__msg-highlight {
  font-weight: 700;
  font-size: 18px;
  line-height: 23.4px;
  color: var(--c-orange);
  letter-spacing: 0.72px;
}

/* 写真グリッド (重なりあり) */
.sec-fv__photos {
  position: relative;
  width: 337px;
  height: 246px;
  flex-shrink: 0;
}

.sec-fv__photo {
  position: absolute;
  overflow: hidden;
}
.sec-fv__photo img {
  position: absolute;
  max-width: none;
}

/* deco01: 172×176px (left:164px, top:70px) */
.sec-fv__photo--deco01 { width: 172px; height: 176px; left: 164px; top: 70px; }
.sec-fv__photo--deco01 img { width: 116.21%; height: 113.01%; left: -0.06%; top: 0.02%; }

/* item1: 337×119px (left:0, top:0) */
.sec-fv__photo--item1 { width: 337px; height: 119px; left: 0; top: 0; }
.sec-fv__photo--item1 img { width: 102.42%; height: 99.95%; left: -2.49%; top: -0.13%; }

/* p135: 150×99px (left:196px, top:45px) */
.sec-fv__photo--p135 { width: 150.14px; height: 99.44px; left: 196.07px; top: 44.69px; }
.sec-fv__photo--p135 img { width: 100%; height: 100%; left: 0; top: 0; }

/* contents: 181×106px (left:1px, top:61px) */
.sec-fv__photo--contents { width: 181.34px; height: 106.27px; left: 1.07px; top: 61.27px; }
.sec-fv__photo--contents img { width: 100.01%; height: 112.85%; left: 0; top: -13.76%; }

/* p210: 122×81px (left:149px, top:133px) */
.sec-fv__photo--p210 { width: 121.88px; height: 80.92px; left: 149.27px; top: 133.41px; }
.sec-fv__photo--p210 img { width: 100%; height: 100%; left: 0; top: 0; }


/* ==========================================================================
   ② About: 介護に美容が欠かせない時代
   ========================================================================== */
.sec-about {
  background: #ffeaf3;
  padding: 40px 16px;
  display: flex;
  justify-content: center;
}

.sec-about__card {
  width: 100%;
  background: var(--c-white);
  border-radius: 19.5px;
  box-shadow: 6px 6px 30px 0 rgba(246, 98, 139, 0.4);
  padding: 40px 24px 20px;
  display: flex;
  justify-content: center;
}

.sec-about__inner {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
}

.sec-about__block {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 22px;
  align-items: center;
}
.sec-about__block:last-child { width: 100%; }

.sec-about__heading {
  font-weight: 700;
  font-size: 21.3px;
  line-height: 34.13px;
  color: var(--c-pink);
  text-align: center;
}

.sec-about__quote {
  font-weight: 700;
  font-size: 14.5px;
  line-height: 23.4px;
  color: var(--c-navy-deep);
  text-align: center;
}

.sec-about__body {
  font-weight: 400;
  font-size: 14.5px;
  line-height: 23.4px;
  color: var(--c-navy-deep);
  text-align: center;
}
.sec-about__body--lg { line-height: 29.25px; }

.sec-about__mixed {
  font-size: 14.5px;
  line-height: 29.25px;
  color: var(--c-navy-deep);
  text-align: center;
}
.sec-about__mixed strong { font-weight: 700; }

.sec-about__accent {
  font-weight: 700;
  color: var(--c-pink-deep);
}

.sec-about__fig { width: 100%; }

.sec-about__fig--sec05 { height: 191.09px; overflow: hidden; }
.sec-about__fig--sec05 img { width: 100%; height: 100%; object-fit: contain; }

.sec-about__fig--makeup { height: 104.31px; overflow: hidden; display: flex; justify-content: center; }
.sec-about__fig--makeup img { width: 44.27%; height: 100%; object-fit: contain; }


/* ==========================================================================
   ③ Appeal: ケアビューティストの3つの魅力
   ========================================================================== */

/* ヘッダー (blue-gray, h:145px) */
.sec-appeal__hd {
  background-color: var(--c-blue-gray);
  height: 145px;
  padding: 0 60px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sec-appeal__hd-inner {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sec-appeal__hd-inner img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* 遷移エリア (bluebar + deco overlay) */
.sec-appeal__transition {
  display: grid;
  grid-template: 230px / 1fr;
}

.sec-appeal__bluebar {
  grid-area: 1/1;
  align-self: start;
  height: 50px;
  background-color: var(--c-blue-gray);
}

.sec-appeal__deco {
  grid-area: 1/1;
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top;
  pointer-events: none;
}

/* メインコンテンツ */
.sec-appeal__body {
  padding: 0 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* --- ストーリー共通 (BEM: .story) --- */
.story {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.story__header {
  display: flex;
  align-items: center;
  justify-content: space-around;
  width: 100%;
}

.story__header--rev {
  flex-direction: row;
  justify-content: space-between;
}
.story__header--rev .story__numblock { margin-left: 0; }

.story__numblock {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: var(--c-pink);
  flex-shrink: 1;
  min-width: 0;
}

.story__num {
  font-weight: 900;
  font-size: 87px;
  line-height: 1.27;
}

.story__subtitle {
  font-weight: 700;
  font-size: 21.3px;
  line-height: 34.13px;
  color: var(--c-pink);
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
}
.story__subtitle--sm { font-size: 20.3px; }

/* 円形写真 */
.story__circle {
  width: 175px;
  height: 175px;
  border-radius: 50%;
  border: 1px solid var(--c-pink);
  overflow: hidden;
  flex-shrink: 0;
  background-color: var(--c-pink-light);
}
.story__circle img { width: 100%; height: 100%; object-fit: cover; }

.story__circle--sm { width: 150px; height: 150px; }

.story__circle--offset2 { margin-right: 15px; }
.story__circle--offset2 img { width: 100%; height: 100%; margin-left: 0; object-fit: cover; }

.story__circle--offset3 img { width: 100%; height: 100%; margin: 0; object-fit: cover; }

/* ボディ */
.story__body { display: flex; flex-direction: column; gap: 8px; }
.story__overlap {
  display: grid;
  grid-template: minmax(140px, auto) / 1fr;
}

/* Story 1: 縦画像を90°回転して横置き */
.photo-rot-wrap {
  grid-area: 1/1;
  align-self: start;
  justify-self: start;
  margin-left: 60px;
  margin-top: 5px;
  width: 222px;
  height: 131px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  pointer-events: none;
}
.photo-rot-inner {
  flex: none;
  width: 130.08px;
  height: 221.7px;
  transform: rotate(90.2deg) skewX(-0.06deg);
  overflow: hidden;
}
.photo-rot-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story__overlap .story__text {
  grid-area: 1/1;
  width: 100%;
  z-index: 1;
}

/* Story 2: テキスト → 写真ストリップ */
.story__overlap--2 {
  display: grid;
  grid-template: 1fr / 1fr;
}
.story__overlap--2 .story__text {
  grid-area: 1 / 1;
  z-index: 1;
  width: 100%;
}

.photo-strip-wrap {
  grid-area: 1 / 1;
  width: 100%;
  overflow: hidden;
  z-index: 0;
}
.photo-strip-wrap img { width: 100%; height: auto; object-fit: cover; }

/* Story 3: 写真を右側に重ねる */
.story__overlap--3 {
  display: grid;
  grid-template: minmax(199px, auto) / 1fr;
}

.photo-sq-wrap {
  grid-area: 1/1;
  align-self: start;
  justify-self: start;
  margin-left: 61px;
  width: 216px;
  height: 199px;
  overflow: hidden;
  pointer-events: none;
}
.photo-sq-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.story__overlap--3 .story__text {
  grid-area: 1/1;
  z-index: 1;
  width: 100%;
  padding-top: 7px;
}

.story__text {
  font-weight: 400;
  font-size: 14.5px;
  line-height: 26.33px;
  color: var(--c-navy-deep);
}
.story__text strong { font-weight: 700; }

.story__note {
  font-weight: 400;
  font-size: 10px;
  line-height: 15px;
  color: var(--c-gray);
}


/* ==========================================================================
   ④ Reason: 介護美容研究所が選ばれる理由
   ========================================================================== */

/* ページヘッダー (ピンク帯 + 矢印) */
.sec-reason__hd {
  background: var(--c-pink);
  height: 88.72px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.sec-reason__hd-text {
  font-weight: 700;
  font-size: 22.2px;
  line-height: 31.2px;
  color: var(--c-white);
  text-align: center;
  white-space: nowrap;
}

.sec-reason__hd-arrow {
  width: 100%;
  height: 19px;
  object-fit: fill;
}

/* サブセクション共通 */
.rsec { width: 100%; padding: 40px 24px; }
.rsec--pink  { background: var(--c-pink-light); }
.rsec--white { background: var(--c-white); }

.rsec__inner {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  width: 100%;
}

/* --- タイトルグリッド (デコ画像 + 見出し の重なりレイアウト) --- */
.rsec-title {
  display: grid;
  grid-template: 1fr / 1fr;
  min-height: 240px;
  width: 100%;
  flex-shrink: 0;
}
.rsec-title--sm { min-height: 140px; }

.rsec-title__heading {
  grid-area: 1/1;
  align-self: start;
  justify-self: center;
  margin-top: 31px;
  width: 100%;
  text-align: center;
  font-weight: 700;
  font-size: 21.3px;
  line-height: 34.13px;
  color: var(--c-pink-deep);
  white-space: nowrap;
  z-index: 1;
}

/* デコ画像ボックス */
.deco-box {
  grid-area: 1/1;
  align-self: start;
  justify-self: center;
  overflow: hidden;
}
.deco-box img { width: 100%; height: auto; object-fit: cover; }

/* Section1 (カリキュラム): 144×131px */
.deco-curriculum { width: 190px; }

/* Section2 (実習): 193×131px */
.deco-training { width: 193px; height: auto; }

/* Section3 (care sweet): 186×131px */
.deco-cs { width: 186px; height: auto; }

/* カリキュラムのみ: サブ画像 (pic01) */
.pic01-box {
  grid-area: 1/1;
  align-self: start;
  justify-self: center;
  margin-top: 130px;
  width: 251.55px;
  height: 119.92px;
  overflow: hidden;
}
.pic01-box img { width: 100%; height: 100%; object-fit: cover; }

/* --- カリキュラムカード --- */
.curriculum-body {
  display: flex;
  flex-direction: column;
  gap: 32px;
  align-items: center;
  width: 100%;
}

.cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
  width: 100%;
}

.card {
  width: 100%;
  border-radius: 20px;
  border: 1px solid;
  padding: 8px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.card--beauty { background: var(--c-pink-pale);   border-color: var(--c-pink); }
.card--care   { background: var(--c-orange-pale);  border-color: var(--c-orange); }
.card--biz    { background: var(--c-green-pale);   border-color: var(--c-green); }

.card__title {
  font-weight: 700;
  font-size: 15.5px;
  line-height: 25.35px;
  text-align: center;
  width: 320px;
  padding-bottom: 4px;
}
.card--beauty .card__title { color: var(--c-pink); }
.card--care   .card__title { color: var(--c-orange); }
.card--biz    .card__title { color: var(--c-green); }

.card__inner {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: 320px;
  gap: 3px;
}

.thumb-row {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  width: 100%;
  margin-bottom: 8px;
}

.thumb {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  width: 100px;
  flex-shrink: 0;
}

.thumb__img { width: 100px; height: 68px; overflow: hidden; flex-shrink: 0; }
.thumb__img img { width: 100%; height: 100%; object-fit: cover; }

.thumb p {
  font-weight: 700;
  font-size: 9.7px;
  line-height: 11.7px;
  color: var(--c-navy-deep);
  text-align: center;
}
.card--care .thumb p,
.card--biz  .thumb p { color: var(--c-navy-mid); }

.card__more {
  font-weight: 700;
  font-size: 10px;
  line-height: 18.52px;
  text-align: right;
  width: 100%;
}
.card--beauty .card__more { color: var(--c-pink); }
.card--care   .card__more { color: var(--c-orange); }
.card--biz    .card__more { color: var(--c-green); }

/* --- 現場実習 写真 --- */
.training-photos {
  display: flex;
  gap: 15px;
  align-items: center;
  justify-content: center;
}

.training-photo { width: 163px; height: 145px; overflow: hidden; flex-shrink: 0; }
.training-photo img { width: 100%; height: 100%; object-fit: cover; }

/* --- care sweet --- */
.cs-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
  width: 100%;
}

.cs-header {
  background: var(--c-storm-gray);
  width: 100%;
  height: 44.84px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  font-weight: 700;
  font-size: 17.3px;
  color: var(--c-white);
  text-align: center;
  white-space: nowrap;
}

.cs-diagram { width: 100%; overflow: hidden; }
.cs-diagram img { width: 100%; object-fit: cover; }

.income-card {
  background: var(--c-white);
  border-radius: 27.3px;
  padding: 24px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  width: 100%;
}

.income-card__chart { 
  width: 70%; 
  height: auto; 
  overflow: hidden; 
}

.income-list { 
  display: flex; 
  flex-direction: column; 
  gap: 5px; width: 100%; 
  list-style: none; 
}
.income-list__item { display: flex; align-items: flex-start; gap: 8px; }

.check-icon { width: 35.09px; height: 33.14px; flex-shrink: 0; overflow: hidden; }
.check-icon img { width: 100%; height: 100%; object-fit: contain; }

.income-list__text {
  font-weight: 700;
  font-size: 16.3px;
  line-height: 26.33px;
}
.income-list__dark { color: var(--c-navy-deep); }
.income-list__pink { color: var(--c-pink-deep); }

.income-note {
  font-weight: 400;
  font-size: 10px;
  line-height: normal;
  color: var(--c-gray-light);
}

.cs-free {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  width: 100%;
}

.cs-free__title {
  font-weight: 700;
  font-size: 15.5px;
  line-height: 25.35px;
  color: var(--c-navy-deep);
  text-align: center;
  white-space: nowrap;
  width: 100%;
}

.cs-free__photos {
  display: flex;
  gap: 16px;
  align-items: center;
  justify-content: center;
  margin-top: 4px;
}

.cs-free__photo { width: 141.38px; height: 163.8px; overflow: hidden; flex-shrink: 0; }
.cs-free__photo img { width: 100%; height: 100%; object-fit: cover; }


/* ==========================================================================
   ⑤ Schools: 全国7校舎
   ========================================================================== */
.sec-schools {
  background: var(--c-white);
  padding: 40px 24px 0;
}

.sec-schools__img {
  width: 100%;
  height: auto;
  display: block;
}


/* ==========================================================================
   ⑥ FAQ: よくある質問
   ========================================================================== */
.sec-faq {
  background: var(--c-white);
  padding: 40px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.sec-faq__title-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 156.97px;
}

.sec-faq__deco {
  width: 100%;
  height: 22.42px;
  overflow: hidden;
  flex-shrink: 0;
}
.sec-faq__deco img {
  width: 100%;
  height: auto;
  display: block;
}

.sec-faq__heading {
  font-weight: 700;
  font-size: 23.2px;
  line-height: 37px;
  color: var(--c-navy-deep);
  text-align: center;
  width: 100%;
}

.sec-faq__list {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
}

.faq-item {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.faq-item__q {
  background: var(--c-whisper);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
}

.faq-item__label {
  font-weight: 700;
  font-size: 14.8px;
  line-height: 25.35px;
  color: var(--c-teal);
  white-space: nowrap;
  flex-shrink: 0;
}

.faq-item__text {
  font-weight: 700;
  font-size: 13.5px;
  line-height: 19.5px;
  color: var(--c-teal);
}

.faq-item__a {
  font-size: 14px;
  line-height: 24.38px;
  color: var(--c-navy-deep);
  margin: 0;
}

.sec-faq__disclaimer {
  font-weight: 400;
  font-size: 10px;
  line-height: 15px;
  color: var(--c-gray);
  width: 100%;
}

/* form */
.form {
  padding: 40px 24px;
  max-width: 450px;
  margin: 0 auto;
}

.wrap-form .small-text--indention {
  font-size: 12px;
  color: #6e728d;
  font-weight: normal;
  line-height: 1.2;
  padding: 0px 0 6px;
  display: block;
  text-align: left;
  font-weight: normal;
  margin-top: -6px;
}

.wrap-form dt span.small-text {
  font-weight: normal;
}

.x_dc68832a {
    text-align: center;
}

.section-block {
  padding: 24px;
  max-width: 450px;
  margin: 0 auto;
}

#element-1239 {
    width: 200px;
    margin: 0 auto 8px;
}

#element-1236, #element-1237, #element-1235, #element-1240 , #element-1241 {
  width: 50px;
  height: auto;
}

  #element-1236 {
    left: 25rem;
  }

  #element-1237 {
    left: 31rem;
  }

#element-1234 {
  font-size: 10px;
  padding: 16px 0 0 0;
  color: #fff;
  text-align: center;
}

#element-1238 {
  padding: 24px 0 0 0;
  font-size: 12px;
  color: #fff;
  text-align: center;
}

  #element-1235 {
    left: 37rem;
  }

  #element-1240 {
    left: 43rem;
  }

  #element-1241 {
    left: 49rem;
  }

#element-1247 {
    padding: 16px 0;
    font-size: 13px;
}

.wrap-form {
  width: 100%;
}


/* footer */

.wrap_footer {
  text-align: center;
  color: #FFF;
  font-size: 0.7em;
  padding: 40px 13%;
}

.wrap_sns {
  max-width: 330px;
    margin: 0 auto;
    display: flex;
    justify-content: space-around;
}

.wrap_sns img {
  width: 55%;
  margin: 0 auto;
}

.fotter-address img {
  margin-bottom: 60px;
}

footer p {
  margin: 5px 0 0;
  color: rgba(255, 255, 255, 0.5);
  ;
}

/* 追従ボタン */
.fixed-button-container {
  z-index: 9998;
  background-color: transparent;
  position: fixed;
  right: 0px;
  bottom: -2px;
  cursor: pointer;
}

.fixed-button-img {
  display: flex;
  justify-content: right;
  transition: .3s;
  align-items: flex-end;
  right: 0;
  bottom: 0;
  width: 280px;
  height: 100%;
  /* 非表示にする */
  opacity: 0;
  visibility: hidden;
}

.fixed-button-img a:hover {
  opacity: unset !important;
}

/*このクラスが付与されると表示する*/
.is-active {
  /* 表示する */
  opacity: 1;
  visibility: visible;
}

/*このクラスが付与されると表示する*/
.absolute {
  visibility: hidden;
}




/*フォーム下*/
#page-block-mjs7ikn9rp {
  background: rgb(72, 74, 96);
}

.wrap-sns {
  max-width: 330px;
  margin: 0 auto;
  display: flex;
  justify-content: space-around;
}

.wrap-form {
  width: 100%;
}

@media screen and (max-width: 768px) {
  .form-content_box-btn button[type="submit"]>b {
    font-size: 1em !important;
  }
}