﻿/* =========================================================
  FV / スマホ調整
  ---------------------------------------------------------
  スマホでは2カラムをやめて、上から順に
  コピー → CTA → 特徴 → 画像
  の縦積みにします。
========================================================= */

/* =========================================================
  FV / コピー＋特徴カード連動型：SP
  ---------------------------------------------------------
  スマホでは2カラムを解除して、
  コピー → CTA → 画像 → 特徴カード
  の順に縦積みします。
========================================================= */

@media (max-width: 768px) {

  /* -------------------------------------------------------
    FV全体
    -------------------------------------------------------
    スマホでは余白を少し小さくします。
  ------------------------------------------------------- */
  .fv-feature {
    padding: 56px 0 48px;
  }


  /* -------------------------------------------------------
    FV内側レイアウト
    -------------------------------------------------------
    PCの2カラムを解除して、1カラムにします。
  ------------------------------------------------------- */
  .fv-feature__inner {
    grid-template-columns: 1fr;
    gap: 36px;
  }


  /* -------------------------------------------------------
    左側コンテンツ
    -------------------------------------------------------
    スマホでは中央寄せにしてFVらしくまとめます。
  ------------------------------------------------------- */
  .fv-feature__content {
    text-align: center;
  }


  /* -------------------------------------------------------
    補足ラベル
    -------------------------------------------------------
    スマホでは少し小さくします。
  ------------------------------------------------------- */
  .fv-feature__label {
    margin-bottom: 18px;
    font-size: 0.8rem;
  }


  /* -------------------------------------------------------
    メインコピー
    -------------------------------------------------------
    スマホで読みやすいサイズにします。
  ------------------------------------------------------- */
  .fv-feature__title {
    font-size: clamp(1.95rem, 8.8vw, 3rem);
    line-height: 1.36;
    letter-spacing: 0.03em;
  }


  /* -------------------------------------------------------
    リード文
    -------------------------------------------------------
    読みやすい行間・文字サイズに調整します。
  ------------------------------------------------------- */
  .fv-feature__lead {
    margin-top: 20px;
    font-size: 0.94rem;
    line-height: 1.9;
    text-align: left;
  }


  /* -------------------------------------------------------
    CTAエリア
    -------------------------------------------------------
    スマホではボタンを縦並びにして押しやすくします。
  ------------------------------------------------------- */
  .fv-feature__buttons {
    display: none;
    gap: 14px;
    margin-top: 30px;
  }


  /* -------------------------------------------------------
    CTAボタン
    -------------------------------------------------------
    common.css 側で .c-btn はスマホ時 width:100% になるため、
    min-widthだけ解除します。
  ------------------------------------------------------- */
  .fv-feature__main-btn,
  .fv-feature__sub-btn {
    min-width: auto;
  }


  /* -------------------------------------------------------
    右側エリア
    -------------------------------------------------------
    スマホではコピー下に表示される通常コンテンツにします。
  ------------------------------------------------------- */
  .fv-feature__visual-area {
    gap: 18px;
  }


  /* -------------------------------------------------------
    メイン画像枠
    -------------------------------------------------------
    スマホでは少し横長の画像枠にします。
  ------------------------------------------------------- */
  .fv-feature__image-frame {
    aspect-ratio: 4 / 3;
    border-radius: var(--radius-m);
  }


  /* -------------------------------------------------------
    特徴カード一覧
    -------------------------------------------------------
    スマホでは1列にして読みやすくします。
  ------------------------------------------------------- */
  .fv-feature__cards {
    grid-template-columns: 1fr;
    gap: 12px;
  }


  /* -------------------------------------------------------
    特徴カード
    -------------------------------------------------------
    スマホではアイコン左・テキスト右の横並びにして、
    縦に長くなりすぎないようにします。
  ------------------------------------------------------- */
  .fv-feature__card {
    grid-template-columns: 54px 1fr;
    justify-items: start;
    align-items: center;
    column-gap: 14px;
    row-gap: 4px;
    padding: 16px;
    text-align: left;
  }


  /* -------------------------------------------------------
    特徴カードアイコン
    -------------------------------------------------------
    スマホでは少し小さくします。
  ------------------------------------------------------- */
  .fv-feature__card-icon {
    grid-row: span 2;
    width: 50px;
    height: 50px;
    font-size: 1.2rem;
  }


  /* -------------------------------------------------------
    特徴カード見出し
    -------------------------------------------------------
    横並びカード内で読みやすいサイズにします。
  ------------------------------------------------------- */
  .fv-feature__card-title {
    font-size: 0.98rem;
  }


  /* -------------------------------------------------------
    特徴カード説明文
    -------------------------------------------------------
    スマホ用に少し小さめにします。
  ------------------------------------------------------- */
  .fv-feature__card-text {
    font-size: 0.8rem;
    line-height: 1.65;
  }
}


/* =========================================================
  さらに小さいスマホ用
========================================================= */

@media (max-width: 430px) {

  /* FV全体の余白調整 */
  .fv-feature {
    padding: 48px 0 44px;
  }

  /* メインコピーを少し小さめに */
  .fv-feature__title {
    font-size: clamp(1.75rem, 8.8vw, 2.55rem);
  }

  /* 特徴カードの内側余白を微調整 */
  .fv-feature__card {
    padding: 14px;
  }
}
/* =========================================================
   Variation B：チェックリストレイアウト / SP
========================================================= */

@media (max-width: 768px) {

  /* 見出し下の説明文 */
  .problem-b__lead {
    font-size: 0.92rem;
  }

  /* リスト全体 */
  .problem-b__list {
    width: 100%;
    gap: 14px;
    margin-top: 28px;
    padding: 28px 20px;
  }

  /* チェック1行 */
  .problem-b__item {
    grid-template-columns: 28px 1fr;
    gap: 10px;
  }

  /* チェックアイコン */
  .problem-b__icon {
    width: 23px;
    height: 23px;
    font-size: 0.8rem;
  }

  /* チェック本文 */
  .problem-b__text {
    font-size: 0.92rem;
  }

  /* CTA */
  .problem-b__cta {
    margin-top: 26px;
  }
}
/* =========================================================
   Variation B：サービス内容をカードで紹介 / SP
========================================================= */

@media (max-width: 768px) {

  /* ラベル折り返し */
  .price-b__top-labels {
    flex-wrap: wrap;
    margin-bottom: 28px;
  }

  /* 2カラム → 縦並び */
  .price-b__inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  /* 見出し */
  .price-b__title {
    font-size: 1.6rem;
  }

  /* リード文 */
  .price-b__lead {
    margin-top: 16px;
    font-size: 0.92rem;
  }

  /* リンク群 */
  .price-b__links {
    margin-top: 28px;
  }

  /* メインリンクを幅いっぱいに */
  .price-b__main-link {
    width: 100%;
  }

  /* カードを縦並び */
  .price-b__cards {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  /* カード */
  .price-b-card {
    min-height: auto;
    padding: 28px 22px 18px;
  }

  /* カード説明 */
  .price-b-card__text {
    min-height: auto;
    font-size: 0.9rem;
  }

  /* ボタン */
  .price-b-card__btn {
    margin-top: 22px;
  }
}
/* =========================================================
   Variation A：アイコンカード型 / SP
========================================================= */

@media (max-width: 768px) {

  .reason-a__heading {
    margin-bottom: 32px;
  }

  .reason-a__title {
    font-size: 1.65rem;
  }

  .reason-a__lead {
    font-size: 0.92rem;
  }

  /* 4列 → 1列 */
  .reason-a__grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .reason-a-card {
    min-height: auto;
    padding: 28px 22px;
  }

  .reason-a-card__icon {
    width: 60px;
    height: 60px;
    margin-bottom: 16px;
    font-size: 1.45rem;
  }

  .reason-a-card__text {
    font-size: 0.9rem;
  }
}
/* =========================================================
   Variation C：画像＋特徴リスト型 / SP
========================================================= */

@media (max-width: 768px) {

  /* 2カラム → 縦並び */
  .reason-c__inner {
    grid-template-columns: 1fr;
    gap: 34px;
  }

  /* 画像エリア */
  .reason-c__placeholder {
    min-height: 240px;
  }

  .reason-c__img {
    height: 240px;
  }

  .reason-c__caption {
    font-size: 0.88rem;
  }

  /* 見出し */
  .reason-c__title {
    font-size: 1.65rem;
  }

  .reason-c__lead {
    font-size: 0.92rem;
  }

  /* リスト */
  .reason-c__list {
    margin-top: 24px;
  }

  /* リスト1行 */
  .reason-c__item {
    grid-template-columns: 40px 1fr;
    gap: 12px;
    padding: 15px 0;
  }

  /* チェックアイコン */
  .reason-c__icon {
    width: 30px;
    height: 30px;
    font-size: 0.86rem;
  }

  .reason-c__item-title {
    font-size: 0.98rem;
  }

  .reason-c__item-text {
    font-size: 0.9rem;
  }
}
/* =========================================================
  制作実績・ポートフォリオ紹介セクション SP調整
========================================================= */

@media (max-width: 768px) {

  /* 背景装飾を小さめにして、スマホで邪魔にならないようにする */
  .p-portfolio::before {
    top: 40px;
    right: -120px;
    width: 220px;
    height: 220px;
  }

  /* 補足文の行幅を整える */
  .p-portfolio__lead {
    font-size: 0.95rem;
    text-align: left;
  }

  /* スマホでは1列表示 */
  .p-portfolio__grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  /* 画像を少し縦長寄りにして、スクショが見やすい比率にする */
  .p-portfolio-card__image {
    aspect-ratio: 4 / 3;
  }

  /* カード内の余白をスマホ用に少し詰める */
  .p-portfolio-card__body {
    padding: 22px;
  }

  .p-portfolio-card__title {
    font-size: 1.12rem;
  }

  .p-portfolio-card__text {
    font-size: 0.92rem;
  }

  /* CTAエリアはスマホで圧迫しないよう余白調整 */
  .p-portfolio__cta {
    margin-top: 36px;
    padding: 28px 20px;
  }

  .p-portfolio__cta-text {
    text-align: left;
  }
}
/* =========================================================
   Variation A：横並びステップ・水平フロー / SP
========================================================= */

@media (max-width: 768px) {

  /* 見出し下の説明文 */
  .flow-a__lead {
    font-size: 0.92rem;
  }

  /* ラベルはスマホで折り返せるようにする */
  .flow-a__top-labels {
    flex-wrap: wrap;
    margin-bottom: 32px;
  }

  /* 5列 → 1列 */
  .flow-a__list {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  /* ステップカード化 */
  .flow-a__item {
    padding: 28px 22px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-m);
    background: var(--color-white);
    box-shadow: var(--shadow-card);
  }

  /* 横矢印はスマホでは非表示 */
  .flow-a__item:not(:last-child)::after {
    display: none;
  }

  /* 丸数字 */
  .flow-a__number {
    width: 38px;
    height: 38px;
    margin-bottom: 14px;
    font-size: 1.2rem;
  }

  /* アイコン枠 */
  .flow-a__icon {
    width: 76px;
    height: 76px;
    margin-bottom: 16px;
    font-size: 1.8rem;
  }

  /* 本文 */
  .flow-a__text {
    font-size: 0.9rem;
  }
}
/* =========================================================
   Variation A：アコーディオン型FAQ / SP
========================================================= */

@media (max-width: 768px) {

  /* 見出し下の説明文 */
  .faq-a__lead {
    font-size: 0.92rem;
  }

  /* ラベルを折り返せるようにする */
  .faq-a__top-labels {
    flex-wrap: wrap;
    margin-bottom: 24px;
  }

  /* 質問行 */
  .faq-a__question {
    grid-template-columns: 34px 1fr 20px;
    gap: 10px;
    min-height: 56px;
    padding: 12px 14px;
  }

  /* Q/Aアイコン */
  .faq-a__q-icon,
  .faq-a__a-icon {
    width: 28px;
    height: 28px;
    font-size: 0.88rem;
  }

  /* 質問テキスト */
  .faq-a__q-text {
    font-size: 0.92rem;
  }

  /* 回答行 */
  .faq-a__answer {
    grid-template-columns: 34px 1fr;
    gap: 10px;
    padding: 0 14px 16px;
  }

  /* 回答テキスト */
  .faq-a__a-text {
    font-size: 0.9rem;
  }
}
/* =========================================================
   Variation A：シンプルなCTAバンド / SP
========================================================= */

@media (max-width: 768px) {

  /* 見出し下の説明文 */
  .cta-a__lead {
    font-size: 0.92rem;
  }

  /* ラベルを折り返し可能にする */
  .cta-a__top-labels {
    flex-wrap: wrap;
    margin-bottom: 24px;
  }

  /* CTA本体 */
  .cta-a__box {
    padding: 40px 20px;
  }

  /* CTA見出し */
  .cta-a__title {
    font-size: 1.55rem;
  }

  /* CTA説明文 */
  .cta-a__text {
    margin-top: 14px;
    font-size: 0.92rem;
  }

  /* CTAボタン */
  .cta-a__btn {
    width: 100%;
    min-width: auto;
    margin-top: 26px;
  }
}