/* ============================================================
   Sol Home – FV ヒーロー v3
   損失回避コピー・信頼チップ・宮城全域訴求
   スマホファースト設計
   Prefix: sol-fv2-
   ============================================================ */

/* ── CSS変数 ── */
.sol-fv2 {
  --fv-orange:    #ff7a00;
  --fv-orange-lt: #ff9c42;
  --fv-white:     #ffffff;
}

/* ================================================================
   外枠
   ================================================================ */
.sol-fv2 {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: #0d1b2a; /* 画像ロード前のフォールバック */
}

/* ================================================================
   背景画像コンテナ
   ================================================================ */
.sol-fv2__bg {
  position: relative;
  width: 100%;
  /* PC: 85vh / 640px〜960px */
  height: clamp(640px, 85vh, 960px);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center 20%;
  display: flex;
  align-items: flex-end; /* テキストを下部に配置して画像を上部に見せる */
}

/* ================================================================
   オーバーレイ
   上部: 薄く → 屋根・パネルの写真がはっきり見える
   下部: 濃く → 白文字が確実に読める
   ================================================================ */
.sol-fv2__overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, .12) 0%,
    rgba(0, 0, 0, .02) 20%,
    rgba(0, 0, 0, .45) 55%,
    rgba(0, 0, 0, .92) 100%
  );
}

/* ================================================================
   コンテンツエリア
   ================================================================ */
.sol-fv2__body {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  padding: 2rem 2.5rem 4.5rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

/* ================================================================
   信頼チップ群
   ================================================================ */
.sol-fv2__chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .45rem .55rem;
  margin: 0;
  list-style: none;
  padding: 0;
}

.sol-fv2__chip {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  padding: .42rem .9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, .15);
  border: 1px solid rgba(255, 255, 255, .28);
  color: #ffffff;
  font-size: clamp(.72rem, 1.8vw, .84rem);
  font-weight: 800;
  letter-spacing: .02em;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  white-space: nowrap;
}

/* アクセントチップ（補助金相談無料）: オレンジ背景で目立たせる */
.sol-fv2__chip--accent {
  background: rgba(255, 122, 0, .82);
  border-color: rgba(255, 122, 0, .6);
}

/* ================================================================
   メインタイトル（損失回避コピー）
   ================================================================ */
.sol-fv2__heading {
  font-size: clamp(2.6rem, 9vw, 5rem); /* スマホ: 41.6px → PC: 80px */
  font-weight: 900;
  color: #ffffff;
  line-height: 1.08;
  margin: 0;
  letter-spacing: -.04em;
  white-space: normal; /* 改行を許可 */
  text-shadow:
    0 2px 24px rgba(0, 0, 0, .60),
    0 0  60px rgba(0, 0, 0, .25);
}

/* "高すぎる" 部分: オレンジでインパクト */
.sol-fv2__heading-accent {
  color: var(--fv-orange-lt);
  text-shadow:
    0 0 40px rgba(255, 122, 0, .6),
    0 2px 24px rgba(0, 0, 0, .50);
}

/* ================================================================
   ブランド名（Sol Home）
   ================================================================ */
.sol-fv2__brand {
  margin: 0;
  font-size: clamp(.82rem, 2vw, 1rem);
  font-weight: 700;
  color: rgba(255, 255, 255, .78);
  letter-spacing: .04em;
  line-height: 1.5;
}
.sol-fv2__brand strong {
  color: #ffffff;
  font-weight: 900;
}

/* ================================================================
   サブコピー
   ================================================================ */
.sol-fv2__lead {
  font-size: clamp(.96rem, 2.6vw, 1.15rem);
  font-weight: 700;
  color: rgba(255, 255, 255, .92);
  margin: 0;
  line-height: 1.75;
  letter-spacing: .02em;
  text-shadow: 0 1px 10px rgba(0, 0, 0, .45);
  max-width: 640px;
}
.sol-fv2__lead strong {
  color: var(--fv-orange-lt);
  font-weight: 900;
}

/* スマホでは <br> を非表示 */
.sol-fv2__pc-br { display: none; }

/* ================================================================
   CTAグループ
   ================================================================ */
.sol-fv2__cta {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: .65rem;
  width: 100%;
  max-width: 440px;
  margin-top: .35rem;
}

/* ── 共通ボタンベース ── */
.sol-fv2__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  text-decoration: none;
  font-weight: 800;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
  white-space: nowrap;
  border-radius: 999px;
}
.sol-fv2__cta-btn:hover {
  transform: translateY(-2px);
}

/* ── LINE ボタン（プライマリ）── */
.sol-fv2__cta-btn--line {
  width: 100%;
  padding: 1.1rem 1.6rem;
  min-height: 60px;
  background: linear-gradient(135deg, var(--fv-orange), var(--fv-orange-lt));
  color: #ffffff !important;
  font-size: clamp(1rem, 2.8vw, 1.12rem);
  box-shadow:
    0 12px 36px rgba(255, 122, 0, .48),
    0 2px 8px  rgba(0, 0, 0, .22);
  letter-spacing: .02em;
}
.sol-fv2__cta-btn--line:hover {
  box-shadow: 0 20px 52px rgba(255, 122, 0, .62);
  color: #ffffff;
}
.sol-fv2__cta-icon {
  width: 20px;
  height: 20px;
  fill: #ffffff;
  flex-shrink: 0;
}

/* ── サブボタン 3種グリッド ── */
.sol-fv2__cta-sub {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  width: 100%;
}

/* ── サブボタン共通 ── */
.sol-fv2__cta-btn--sub {
  flex-direction: column;
  gap: .22rem;
  padding: .85rem .5rem;
  min-height: 54px;
  background: rgba(0, 0, 0, .55);
  border: 1px solid rgba(255, 255, 255, .28);
  color: #ffffff !important;
  font-size: clamp(.78rem, 1.9vw, .9rem);
  border-radius: 14px;
  text-align: center;
  line-height: 1.25;
  text-shadow: 0 1px 5px rgba(0, 0, 0, .55);
  transition: background .22s ease, border-color .22s ease, transform .22s ease;
}
/* サブボタン内の全子要素を白に固定 */
.sol-fv2__cta-btn--sub,
.sol-fv2__cta-btn--sub * {
  color: #ffffff !important;
  opacity: 1 !important;
  visibility: visible !important;
}
.sol-fv2__cta-btn--sub:hover {
  background: rgba(255, 122, 0, .55);
  border-color: rgba(255, 122, 0, .65);
  color: #ffffff !important;
}

/* ================================================================
   安心メモ
   ================================================================ */
.sol-fv2__note {
  margin: .2rem 0 0;
  font-size: clamp(.72rem, 1.8vw, .82rem);
  color: rgba(255, 255, 255, .65);
  letter-spacing: .06em;
  line-height: 1.5;
}

/* ================================================================
   PC（769px以上）
   ================================================================ */
@media (min-width: 769px) {
  .sol-fv2__body {
    padding: 2rem 3.5rem 5.5rem;
    gap: 1.2rem;
    max-width: 1000px;
  }

  /* PC: LINE + サブ3つを横一列 */
  .sol-fv2__cta {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    max-width: 760px;
    gap: .65rem;
    align-items: center;
  }

  .sol-fv2__cta-btn--line {
    width: auto;
    min-width: 220px;
    flex-shrink: 0;
  }

  /* PC: サブボタン横並び */
  .sol-fv2__cta-sub {
    display: flex;
    gap: .6rem;
    width: auto;
  }

  /* PC: サブボタン形状を pill に */
  .sol-fv2__cta-btn--sub {
    flex-direction: row;
    gap: .35rem;
    min-width: 110px;
    border-radius: 999px;
    padding: .88rem 1.15rem;
    font-size: .88rem;
  }

  /* PC: <br> を表示して2行に */
  .sol-fv2__pc-br { display: inline; }
}

/* ================================================================
   スマホ（768px以下）
   ================================================================ */
@media (max-width: 768px) {
  .sol-fv2__bg {
    height: clamp(560px, 72vh, 760px);
    background-position: center 18%;
  }
  .sol-fv2__body {
    padding: 1.5rem 1.25rem 2.75rem;
    gap: .88rem;
  }
  .sol-fv2__chips {
    gap: .38rem .45rem;
  }
  .sol-fv2__chip {
    font-size: .76rem;
    padding: .38rem .78rem;
  }
  .sol-fv2__cta {
    max-width: 100%;
  }
}

/* ================================================================
   小型スマホ（480px以下）
   ================================================================ */
@media (max-width: 480px) {
  .sol-fv2__bg {
    height: clamp(520px, 68vh, 680px);
  }
  .sol-fv2__body {
    padding: 1.25rem 1rem 2.5rem;
    gap: .78rem;
  }
  .sol-fv2__heading {
    font-size: clamp(2.4rem, 11vw, 3.2rem);
    letter-spacing: -.03em;
  }
  .sol-fv2__cta-btn--sub {
    font-size: .74rem;
    padding: .75rem .4rem;
    min-height: 52px;
  }
}

/* ================================================================
   社会的証明バー
   ================================================================ */
.sol-fv2__social-proof {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: .28rem .75rem;
  margin: 0;
  font-size: clamp(.74rem, 1.85vw, .88rem);
  color: rgba(255, 255, 255, .68);
  letter-spacing: .02em;
  line-height: 1.6;
}
.sol-fv2__social-proof strong {
  color: rgba(255, 255, 255, .96);
  font-weight: 900;
}
.sol-fv2__proof-dot {
  color: rgba(255, 255, 255, .28);
  font-size: .6rem;
  line-height: 1;
}

/* ================================================================
   LINE ボタン パルスアニメーション（視線誘導）
   ================================================================ */
@keyframes sol-fv-pulse {
  0%, 100% {
    box-shadow:
      0 12px 36px rgba(255, 122, 0, .48),
      0 2px 8px  rgba(0, 0, 0, .22);
  }
  50% {
    box-shadow:
      0 18px 52px rgba(255, 122, 0, .68),
      0 4px 12px  rgba(0, 0, 0, .28),
      0 0   0 6px rgba(255, 122, 0, .14);
  }
}

.sol-fv2__cta-btn--line {
  animation: sol-fv-pulse 2.8s ease-in-out infinite;
}
.sol-fv2__cta-btn--line:hover,
.sol-fv2__cta-btn--line:focus-visible {
  animation: none; /* ホバー時はアニメ停止 */
}

/* ================================================================
   モーション軽減
   ================================================================ */
@media (prefers-reduced-motion: reduce) {
  .sol-fv2__cta-btn {
    transition: none;
  }
  .sol-fv2__cta-btn--line {
    animation: none;
  }
}
