﻿/* =========================================================
  FV / ファーストビュー
  ---------------------------------------------------------
  このCSSは、FV専用のレイアウト・装飾です。
  色・角丸・影・横幅などは common.css の :root 変数を使います。
========================================================= */


/* =========================================================
  FV / コピー＋特徴カード連動型：PC
  ---------------------------------------------------------
  左にコピー・CTA、右に画像と特徴カードを配置する
  Variation G 専用CSSです。
========================================================= */


/* ---------------------------------------------------------
  FV全体
  ---------------------------------------------------------
  セクション全体の背景と余白を設定します。
--------------------------------------------------------- */
.fv-feature {
  position: relative;
  overflow: hidden;
  padding: 88px 0 96px;
  background:
    radial-gradient(circle at 16% 24%, rgba(95, 195, 184, 0.12), transparent 28%),
    linear-gradient(135deg, var(--color-bg) 0%, var(--color-sub) 100%);
}


/* ---------------------------------------------------------
  FV内側レイアウト
  ---------------------------------------------------------
  PCでは左にコピー、右に画像＋特徴カードを置く2カラムです。
--------------------------------------------------------- */
.fv-feature__inner {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(460px, 1.05fr);
  align-items: center;
  gap: 72px;
}


/* ---------------------------------------------------------
  左側コンテンツ
  ---------------------------------------------------------
  ラベル・見出し・リード文・CTAをまとめるエリアです。
--------------------------------------------------------- */
.fv-feature__content {
  position: relative;
  z-index: 2;
}


/* ---------------------------------------------------------
  補足ラベル
  ---------------------------------------------------------
  common.css の .c-label に、FV用の余白を追加します。
--------------------------------------------------------- */
.fv-feature__label {
  margin-bottom: 24px;
}


/* ---------------------------------------------------------
  メインコピー
  ---------------------------------------------------------
  FVで最も目立たせる見出しです。
--------------------------------------------------------- */
.fv-feature__title {
  color: var(--color-text);
  font-size: clamp(2.35rem, 4.4vw, 4.15rem);
  font-weight: 700;
  line-height: 1.34;
  letter-spacing: 0.04em;
}


/* ---------------------------------------------------------
  リード文
  ---------------------------------------------------------
  メインコピーを補足する説明文です。
--------------------------------------------------------- */
.fv-feature__lead {
  margin-top: 28px;
  color: var(--color-text);
  font-size: 1.02rem;
  line-height: 2;
}


/* ---------------------------------------------------------
  CTAエリア
  ---------------------------------------------------------
  メインCTAとサブCTAを横並びにします。
--------------------------------------------------------- */
.fv-feature__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 40px;
}


/* ---------------------------------------------------------
  CTAボタン
  ---------------------------------------------------------
  common.css の .c-btn を使いつつ、FV用の横幅に調整します。
--------------------------------------------------------- */
.fv-feature__main-btn,
.fv-feature__sub-btn {
  min-width: 220px;
  gap: 10px;
}


/* ---------------------------------------------------------
  ボタン内アイコン
  ---------------------------------------------------------
  ダウンロードや資料感を出す小さなアイコンです。
--------------------------------------------------------- */
.fv-feature__btn-icon {
  font-size: 1rem;
  line-height: 1;
}


/* ---------------------------------------------------------
  右側：画像＋特徴カードエリア
  ---------------------------------------------------------
  メイン画像と特徴カード3枚を縦に並べる領域です。
--------------------------------------------------------- */
.fv-feature__visual-area {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 24px;
}


/* ---------------------------------------------------------
  メイン画像枠
  ---------------------------------------------------------
  ワイヤーフレーム右上の大きな画像エリアです。
--------------------------------------------------------- */
.fv-feature__image-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--radius-m);
  background:
    linear-gradient(45deg, transparent 49.7%, rgba(31, 122, 122, 0.18) 50%, transparent 50.3%),
    linear-gradient(-45deg, transparent 49.7%, rgba(31, 122, 122, 0.18) 50%, transparent 50.3%),
    rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(31, 122, 122, 0.12);
  box-shadow: var(--shadow-card);
}


/* ---------------------------------------------------------
  メイン画像
  ---------------------------------------------------------
  画像を枠いっぱいに表示します。
--------------------------------------------------------- */
.fv-feature__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ---------------------------------------------------------
  特徴カード一覧
  ---------------------------------------------------------
  画像の下に3枚の特徴カードを並べます。
--------------------------------------------------------- */
.fv-feature__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}


/* ---------------------------------------------------------
  特徴カード1枚
  ---------------------------------------------------------
  アイコン・見出し・説明文を縦に並べます。
--------------------------------------------------------- */
.fv-feature__card {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 24px 18px 22px;
  border-radius: var(--radius-m);
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(31, 122, 122, 0.12);
  box-shadow: var(--shadow-card);
  text-align: center;
}


/* ---------------------------------------------------------
  特徴カードのアイコン
  ---------------------------------------------------------
  丸型のアイコンを配置します。
--------------------------------------------------------- */
.fv-feature__card-icon {
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: rgba(95, 195, 184, 0.14);
  border: 1px solid rgba(31, 122, 122, 0.12);
  color: var(--color-main);
  font-size: 1.45rem;
  font-weight: 700;
}


/* ---------------------------------------------------------
  特徴カード見出し
  ---------------------------------------------------------
  「かんたん導入」などの短い強みです。
--------------------------------------------------------- */
.fv-feature__card-title {
  color: var(--color-text);
  font-size: 1rem;
  line-height: 1.5;
}


/* ---------------------------------------------------------
  特徴カード説明文
  ---------------------------------------------------------
  強みを補足する短いテキストです。
--------------------------------------------------------- */
.fv-feature__card-text {
  color: var(--color-text-light);
  font-size: 0.82rem;
  line-height: 1.7;
}
/* =========================================================
   Variation B：チェックリストレイアウト / PC
========================================================= */

/* セクション全体 */
.problem-b {
  background: var(--color-bg-soft);
}

/* 見出し下の説明文 */
.problem-b__lead {
  margin-top: 12px;
  color: var(--color-text-light);
  font-size: 0.98rem;
}

/* ラベル中央配置 */
.problem-b__label-wrap {
  margin-bottom: 22px;
  text-align: center;
}

/* チェックリスト全体 */
.problem-b__list {
  display: grid;
  gap: 16px;
  width: min(100%, 720px);
  margin: 34px auto 0;
  padding: 36px 42px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background: var(--color-white);
  box-shadow: var(--shadow-card);
}

/* チェックリスト1行 */
.problem-b__item {
  display: grid;
  grid-template-columns: 30px 1fr;
  align-items: start;
  gap: 14px;
}

/* チェックアイコン */
.problem-b__icon {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  margin-top: 3px;
  border: 1px solid var(--color-main);
  border-radius: 5px;
  color: var(--color-main);
  font-size: 0.85rem;
  font-weight: 700;
}

/* チェックリスト本文 */
.problem-b__text {
  color: var(--color-text);
  font-size: 0.98rem;
  line-height: 1.8;
}

/* CTAエリア */
.problem-b__cta {
  margin-top: 30px;
  text-align: center;
}

/* CTAリンク */
.problem-b__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 4px;
  border-bottom: 1px dashed var(--color-main);
  color: var(--color-main);
  font-weight: 700;
}

/* 矢印 */
.problem-b__link-arrow {
  font-size: 1.2em;
  line-height: 1;
}
/* =========================================================
   Variation B：サービス内容をカードで紹介 / PC
========================================================= */

/* セクション全体 */
.price-b {
  background: var(--color-bg-soft);
}

/* 上部ラベル群 */
.price-b__top-labels {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 36px;
}

/* Variation B ラベル */
.price-b__variation-label {
  display: inline-block;
  padding: 8px 14px;
  border-radius: var(--radius-s);
  background: var(--color-white);
  color: var(--color-text);
  font-size: 0.88rem;
  font-weight: 700;
}

/* 左テキスト + 右カード */
.price-b__inner {
  display: grid;
  grid-template-columns: 0.85fr 2.15fr;
  align-items: center;
  gap: 48px;
}

/* 左側テキスト */
.price-b__content {
  min-width: 0;
}

/* 見出し */
.price-b__title {
  font-size: clamp(1.7rem, 2.7vw, 2.4rem);
  line-height: 1.45;
  font-weight: 700;
}

/* リード文 */
.price-b__lead {
  margin-top: 22px;
  color: var(--color-text-light);
  font-size: 1rem;
  line-height: 1.9;
}

/* 左側リンク群 */
.price-b__links {
  display: grid;
  gap: 16px;
  margin-top: 34px;
  justify-items: start;
}

/* メインリンク */
.price-b__main-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 220px;
  min-height: 52px;
  padding: 12px 20px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-white);
  color: var(--color-text);
  font-weight: 700;
}

/* サブリンク */
.price-b__sub-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-bottom: 4px;
  border-bottom: 1px dashed var(--color-main);
  color: var(--color-main);
  font-weight: 700;
}

/* サービスカード3列 */
.price-b__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}

/* サービスカード */
.price-b-card {
  display: flex;
  flex-direction: column;
  min-height: 330px;
  padding: 30px 22px 18px;
  text-align: center;
}

/* アイコン丸 */
.price-b-card__icon {
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: rgba(95, 195, 184, 0.16);
  color: var(--color-main);
  font-size: 1.7rem;
  font-weight: 700;
}

/* カードタイトル */
.price-b-card__title {
  margin-bottom: 12px;
  font-size: 1.15rem;
  font-weight: 700;
}

/* カード説明 */
.price-b-card__text {
  min-height: 58px;
  color: var(--color-text-light);
  font-size: 0.9rem;
  line-height: 1.7;
}

/* 機能リスト */
.price-b-card__list {
  display: grid;
  gap: 8px;
  margin-top: 20px;
  text-align: left;
}

/* リスト1行 */
.price-b-card__list li {
  position: relative;
  padding-left: 22px;
  color: var(--color-text);
  font-size: 0.9rem;
}

/* チェックマーク */
.price-b-card__list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-main);
  font-weight: 700;
}

/* カード下部ボタン */
.price-b-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 48px;
  margin-top: auto;
  padding: 10px 18px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-bg-soft);
  color: var(--color-text);
  font-size: 0.9rem;
  font-weight: 700;
}

/* 装飾用 */
.price-b .c-deco--right-top {
  top: 40px;
  right: -60px;
}

.price-b .c-deco--left-bottom {
  bottom: 40px;
  left: -40px;
}


/* =========================================================
   Variation A：アイコンカード型 / PC
========================================================= */

/* セクション全体 */
.reason-a {
  background: #ffffff;
}

/* 小見出しラベル */
.reason-a__label {
  margin-bottom: 18px;
}

/* 見出しエリア */
.reason-a__heading {
  margin-bottom: 40px;
}

/* メインタイトル */
.reason-a__title {
  font-size: clamp(1.9rem, 3vw, 2.8rem);
  line-height: 1.4;
  font-weight: 700;
}

/* リード文 */
.reason-a__lead {
  margin-top: 18px;
  color: var(--color-text-light);
  font-size: 1rem;
  line-height: 1.9;
}

/* カードを横並びにするグリッド */
.reason-a__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* 特徴カード本体 */
.reason-a-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-height: 230px;
  padding: 34px 24px;
  text-align: center;
}

/* アイコン丸枠 */
.reason-a-card__icon {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  margin-bottom: 20px;
  border: 1px solid var(--color-border);
  border-radius: 50%;
  color: var(--color-main);
  font-size: 1.8rem;
  font-weight: 700;
  background: var(--color-bg-soft);
}

/* カードタイトル */
.reason-a-card__title {
  margin-bottom: 12px;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.6;
}

/* カード本文 */
.reason-a-card__text {
  color: var(--color-text-light);
  font-size: 0.92rem;
  line-height: 1.8;
}
/* =========================================================
   Variation C：画像＋特徴リスト型 / PC
========================================================= */

/* セクション全体 */
.reason-c {
  background: #ffffff;
}

/* 画像＋テキストの2カラム */
.reason-c__inner {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  align-items: center;
  gap: 56px;
}

/* 左の画像エリア */
.reason-c__visual {
  text-align: center;
}

/* 仮画像枠 */
.reason-c__placeholder {
  display: grid;
  place-items: center;
  min-height: 360px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background:
    linear-gradient(to top right, transparent 49.7%, var(--color-border) 50%, transparent 50.3%),
    linear-gradient(to bottom right, transparent 49.7%, var(--color-border) 50%, transparent 50.3%),
    var(--color-bg-soft);
  overflow: hidden;
}

/* 仮画像アイコン */
.reason-c__placeholder-icon {
  color: var(--color-main);
  font-size: 3rem;
}

/* 実画像を入れる場合 */
.reason-c__img {
  width: 100%;
  height: 360px;
  border-radius: var(--radius-m);
  object-fit: cover;
}

/* 画像下キャプション */
.reason-c__caption {
  margin-top: 14px;
  color: var(--color-text-light);
  font-size: 0.92rem;
}

/* 右側テキストエリア */
.reason-c__content {
  min-width: 0;
}

/* 小見出しラベル */
.reason-c__label {
  margin-bottom: 18px;
}

/* 見出し */
.reason-c__title {
  font-size: clamp(1.9rem, 3vw, 2.8rem);
  line-height: 1.4;
  font-weight: 700;
}

/* リード文 */
.reason-c__lead {
  margin-top: 12px;
  color: var(--color-text-light);
  font-size: 1rem;
  line-height: 1.8;
}

/* 特徴リスト全体 */
.reason-c__list {
  display: grid;
  gap: 0;
  margin-top: 28px;
}

/* 特徴リスト1行 */
.reason-c__item {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 14px;
  padding: 16px 0;
  border-bottom: 1px dashed var(--color-border);
}

/* チェックアイコン */
.reason-c__icon {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  margin-top: 2px;
  border: 1px solid var(--color-main);
  border-radius: 50%;
  color: var(--color-main);
  font-size: 0.95rem;
  font-weight: 700;
}

/* テキスト全体 */
.reason-c__text-wrap {
  display: grid;
  gap: 4px;
}

/* 特徴タイトル */
.reason-c__item-title {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.5;
}

/* 特徴説明文 */
.reason-c__item-text {
  color: var(--color-text-light);
  font-size: 0.92rem;
  line-height: 1.7;
}
/* =========================================================
  制作実績・ポートフォリオ紹介セクション
  ---------------------------------------------------------
  key-common.css の共通変数・共通パーツを前提にした追加CSSです。
  DB化する時は「portfolio」「works」「case」系カテゴリとして
  登録すると流用しやすいです。
========================================================= */

.p-portfolio {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(95, 195, 184, 0.12), transparent 34%),
    linear-gradient(180deg, var(--color-bg) 0%, var(--color-bg-soft) 100%);
}

/* 背景の薄い装飾。セクション全体にやわらかさを出す */
.p-portfolio::before {
  content: "";
  position: absolute;
  top: 80px;
  right: -90px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: rgba(95, 195, 184, 0.12);
  z-index: 0;
}

/* 中身を背景装飾より前面に出す */
.p-portfolio .l-container {
  position: relative;
  z-index: 1;
}

/* 見出し下の補足文 */
.p-portfolio__lead {
  margin-top: 18px;
  color: var(--color-text-light);
  font-size: 1rem;
}

/* 実績カードを3列で並べる */
.p-portfolio__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* 既存の .c-card に追加して、実績カードらしい縦型レイアウトにする */
.p-portfolio-card {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
}

/* スクリーンショット画像の枠 */
.p-portfolio-card__image {
  display: block;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-bg-soft);
}

/* 画像はカードいっぱいに表示。スクショの見栄えを整える */
.p-portfolio-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

/* hover時に少しだけ拡大して、クリックできる印象を出す */
.p-portfolio-card__image:hover img {
  transform: scale(1.04);
}

/* カード内の文章エリア */
.p-portfolio-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 24px;
}

/* カテゴリラベル */
.p-portfolio-card__category {
  width: fit-content;
  margin-bottom: 12px;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  background: rgba(95, 195, 184, 0.14);
  color: var(--color-main);
  font-size: 0.78rem;
  font-weight: 700;
}

/* 実績タイトル */
.p-portfolio-card__title {
  margin-bottom: 10px;
  color: var(--color-text);
  font-size: 1.22rem;
  line-height: 1.5;
}

/* 実績説明文 */
.p-portfolio-card__text {
  color: var(--color-text-light);
  font-size: 0.94rem;
  line-height: 1.8;
}

/* タグ一覧 */
.p-portfolio-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 20px;
}

/* タグ単体 */
.p-portfolio-card__tags li {
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  background: var(--color-bg-soft);
  color: var(--color-text-light);
  font-size: 0.78rem;
  font-weight: 700;
}

/* セクション下部のCTA */
.p-portfolio__cta {
  margin-top: 48px;
  padding: 34px;
  border-radius: var(--radius-l);
  background: var(--color-white);
  text-align: center;
  box-shadow: var(--shadow-card);
}

/* CTAの補足文 */
.p-portfolio__cta-text {
  margin-bottom: 18px;
  color: var(--color-text);
  font-weight: 700;
}
/* =========================================================
   Variation A：横並びステップ・水平フロー / PC
========================================================= */

/* セクション全体 */
.flow-a {
  background: #ffffff;
}

/* 見出し下の説明文 */
.flow-a__lead {
  margin-top: 12px;
  color: var(--color-text-light);
  font-size: 0.98rem;
}

/* 上部ラベル群 */
.flow-a__top-labels {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 42px;
}

/* Variation A ラベル */
.flow-a__variation-label {
  display: inline-block;
  padding: 8px 14px;
  border-radius: var(--radius-s);
  background: var(--color-bg-soft);
  color: var(--color-text);
  font-size: 0.88rem;
  font-weight: 700;
}

/* 小見出しラベル */
.flow-a__section-label {
  font-size: 0.88rem;
}

/* ステップ一覧 */
.flow-a__list {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 34px;
  counter-reset: flow-number;
}

/* ステップ1つ分 */
.flow-a__item {
  position: relative;
  text-align: center;
}

/* ステップ間の矢印 */
.flow-a__item:not(:last-child)::after {
  content: "→";
  position: absolute;
  top: 18px;
  right: -28px;
  color: var(--color-text-light);
  font-size: 1.8rem;
  line-height: 1;
}

/* 丸数字 */
.flow-a__number {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  margin: 0 auto 18px;
  border: 2px solid var(--color-main);
  border-radius: 50%;
  background: var(--color-white);
  color: var(--color-main);
  font-size: 1.35rem;
  font-weight: 700;
}

/* アイコン枠 */
.flow-a__icon {
  display: grid;
  place-items: center;
  width: 94px;
  height: 94px;
  margin: 0 auto 18px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-bg-soft);
  color: var(--color-main);
  font-size: 2.2rem;
}

/* ステップ見出し */
.flow-a__title {
  margin-bottom: 10px;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.6;
}

/* ステップ本文 */
.flow-a__text {
  color: var(--color-text-light);
  font-size: 0.9rem;
  line-height: 1.8;
}

/* 装飾用 */
.flow-a .c-deco--right-top {
  top: 40px;
  right: -60px;
}

.flow-a .c-deco--left-bottom {
  bottom: 40px;
  left: -40px;
}


/* =========================================================
   Variation A：アコーディオン型FAQ / PC
========================================================= */

/* セクション全体 */
.faq-a {
  background: #ffffff;
}

/* 見出し下の説明文 */
.faq-a__lead {
  margin-top: 12px;
  color: var(--color-text-light);
  font-size: 0.98rem;
}

/* 上部ラベル群 */
.faq-a__top-labels {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 30px;
}

/* Variation A ラベル */
.faq-a__variation-label {
  display: inline-block;
  padding: 8px 14px;
  border-radius: var(--radius-s);
  background: var(--color-bg-soft);
  color: var(--color-text);
  font-size: 0.88rem;
  font-weight: 700;
}

/* FAQリスト全体 */
.faq-a__list {
  display: grid;
  gap: 10px;
}

/* details のデフォルト三角を消すための指定 */
.faq-a__question {
  list-style: none;
}

.faq-a__question::-webkit-details-marker {
  display: none;
}

/* FAQ 1項目 */
.faq-a__item {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-s);
  background: var(--color-white);
}

/* 質問行 */
.faq-a__question {
  display: grid;
  grid-template-columns: 40px 1fr 24px;
  align-items: center;
  gap: 12px;
  min-height: 58px;
  padding: 12px 18px;
  cursor: pointer;
}

/* Qアイコン */
.faq-a__q-icon,
.faq-a__a-icon {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--color-border);
  border-radius: 50%;
  background: var(--color-bg-soft);
  color: var(--color-main);
  font-weight: 700;
  line-height: 1;
}

/* 質問テキスト */
.faq-a__q-text {
  font-weight: 700;
  line-height: 1.7;
}

/* 右端の開閉矢印 */
.faq-a__arrow {
  position: relative;
  width: 16px;
  height: 16px;
}

/* 矢印の線 */
.faq-a__arrow::before,
.faq-a__arrow::after {
  content: "";
  position: absolute;
  top: 7px;
  width: 10px;
  height: 2px;
  background: var(--color-text-light);
}

/* 下向きの矢印に見せる */
.faq-a__arrow::before {
  left: 0;
  transform: rotate(45deg);
}

.faq-a__arrow::after {
  right: 0;
  transform: rotate(-45deg);
}

/* 開いた時は上向きにする */
.faq-a__item[open] .faq-a__arrow::before {
  transform: rotate(-45deg);
}

.faq-a__item[open] .faq-a__arrow::after {
  transform: rotate(45deg);
}

/* 回答行 */
.faq-a__answer {
  display: grid;
  grid-template-columns: 40px 1fr;
  gap: 12px;
  padding: 0 18px 18px;
}

/* 回答テキスト */
.faq-a__a-text {
  color: var(--color-text-light);
  font-size: 0.95rem;
  line-height: 1.9;
}
/* =========================================================
   Variation A：シンプルなCTAバンド / PC
========================================================= */

/* セクション全体 */
.cta-a {
  background: #ffffff;
}

/* 見出し下の説明文 */
.cta-a__lead {
  margin-top: 12px;
  color: var(--color-text-light);
  font-size: 0.98rem;
}

/* 上部ラベル群 */
.cta-a__top-labels {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 30px;
}

/* Variation A ラベル */
.cta-a__variation-label {
  display: inline-block;
  padding: 8px 14px;
  border-radius: var(--radius-s);
  background: var(--color-bg-soft);
  color: var(--color-text);
  font-size: 0.88rem;
  font-weight: 700;
}

/* CTA本体の大きな箱 */
.cta-a__box {
  padding: 56px 32px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  background: linear-gradient(180deg, #ffffff 0%, var(--color-bg-soft) 100%);
  text-align: center;
  box-shadow: var(--shadow-card);
}

/* CTA見出し */
.cta-a__title {
  font-size: clamp(1.6rem, 2.6vw, 2.3rem);
  line-height: 1.45;
  font-weight: 700;
}

/* CTA説明文 */
.cta-a__text {
  margin-top: 18px;
  color: var(--color-text-light);
  font-size: 1rem;
  line-height: 1.9;
}

/* CTAボタン */
.cta-a__btn {
  margin-top: 30px;
  min-width: 320px;
}

/* ボタン内矢印 */
.cta-a__btn-arrow {
  margin-left: 10px;
  font-size: 1.15em;
}