/* ==================================================
   1. Reset & Base Styles
================================================== */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --color-primary: #0f172a;    /* 深みのあるネイビー */
  --color-accent: #d4b07b;     /* 上品なゴールド */
  --color-bg-light: #f8f5f2;   /* 柔らかなベージュ */
  --color-bg-gray: #f9fafb;    /* 背景用ライトグレー */
  --color-border: #e5e7eb;     /* ボーダー用のグレー */
  --color-text: #333333;       /* 基本の文字色 */
  --color-text-light: #6b7280; /* サブテキスト用のグレー */
  --font-base: 'Noto Sans JP', sans-serif;
  --font-title: 'Shippori Mincho', serif;
}

body {
  font-family: var(--font-base);
  color: var(--color-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

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

ul {
  list-style: none;
}

a {
  text-decoration: none;
  color: inherit;
}

/* ==================================================
   Utility Classes (表示切り替えなど)
================================================== */
.pc-only {
  display: block;
}

.sp-br {
  display: none;
}

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

/* 共通セクションヘッダー */
.section-header {
  text-align: center;
  margin-bottom: 50px;
}
.section-en {
  font-size: 0.9rem;
  color: var(--color-accent);
  letter-spacing: 0.2em;
  margin-bottom: 10px;
}
.section-jp {
  font-family: var(--font-title);
  font-size: 2rem;
  color: var(--color-primary);
}

.reason-container, .worry-container, .step-container, .faq-container, .voice-container, .track-record-container, .media-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ==================================================
   2. Header Styles (ハンバーガーなし・SP最適化版)
================================================== */
.header-area {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 70px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  z-index: 1000;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
}

.header-container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.header-logo a {
  text-decoration: none;
  font-family: var(--font-title);
  font-size: 1.3rem;
  color: var(--color-primary);
  letter-spacing: 0.05em;
}

.header-logo-jp {
  font-size: 0.8rem;
  font-family: var(--font-base);
  color: var(--color-accent); 
  margin-left: 4px;
}

.header-btn {
  background: var(--color-primary);
  color: #fff;
  padding: 10px 24px;
  font-size: 0.9rem;
  font-weight: bold;
  border-radius: 4px;
  text-decoration: none;
  border: 1px solid var(--color-accent);
  transition: all 0.3s ease;
  display: inline-block;
}

.header-btn:hover {
  background: var(--color-accent);
  color: var(--color-primary);
}

.header-nav ul {
  display: flex;
  gap: 30px;
  list-style: none;
}

.header-nav a {
  text-decoration: none;
  color: var(--color-primary);
  font-size: 0.9rem;
  font-weight: 500;
  transition: color 0.3s;
}

.header-nav a:hover {
  color: var(--color-accent);
}

@media (max-width: 768px) {
  .header-logo a { font-size: 1.1rem; }
  .header-logo-jp { font-size: 0.7rem; }
  .header-btn { padding: 8px 16px; font-size: 0.8rem; }
}

/* ==================================================
   First View (FV) Section
================================================== */
.fv-section {
  position: relative;
  height: 100dvh;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  background-color: #000;
}

.fv-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url('../img/fv.webp') center/cover no-repeat;
  z-index: 0;
}

.fv-bg::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.8) 100%);
}

.fv-container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1000px;
  padding: 0 20px;
  text-align: center;
}

.fv-text-block {
  color: #FFFFFF;
}

.fv-text-block * {
  text-shadow: 0 4px 15px rgba(0, 0, 0, 0.8);
}

.simple-line-btn {
  display: inline-block;
  background: var(--color-primary);
  color: #FFFFFF;
  padding: 20px 60px;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-decoration: none;
  border: 1px solid var(--color-accent);
  transition: all 0.3s ease;
}

.simple-line-btn:hover {
  background: var(--color-accent);
  color: var(--color-primary);
  transform: translateY(-3px);
}

/* ==================================================
   4. Worry Section
================================================== */
.worry-section {
  padding: 100px 0;
}
.worry-title {
  text-align: center;
  font-size: 1.5rem;
  font-weight: normal;
  margin-bottom: 50px;
}
.worry-highlight {
  color: var(--color-accent);
}

.worry-content-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 50px;
  gap: 40px;
}

.worry-image-wrapper {
  flex: 0 0 45%;
  padding: 0;
  background: #FFFFFF;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
  border-radius: 4px;
  overflow: hidden;
}

.worry-image-wrapper img {
  width: 100%;
  height: auto;
  display: block;
}

.worry-box {
  flex: 1;
}
.worry-list li {
  position: relative;
  padding-left: 25px;
  margin-bottom: 15px;
  color: var(--color-text);
}
.worry-list li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: var(--color-accent);
}

.worry-solution {
  text-align: center;
  background: var(--color-bg-gray);
  padding: 40px 20px;
}
.worry-solution-lead {
  font-size: 1.2rem;
  color: var(--color-primary);
  margin-bottom: 15px;
}

@media (max-width: 768px) {
  .worry-content-wrapper { flex-direction: column; }
  .worry-image-wrapper { flex: 0 0 100%; width: 100%; }
}

/* ==================================================
   5. Reason Section
================================================== */
.reason-section {
  padding: 100px 0;
  background: #FFFFFF;
}
.reason-item {
  display: flex;
  gap: 50px;
  align-items: center;
  margin-bottom: 80px;
}
.reason-item.reverse {
  flex-direction: row-reverse;
}
.reason-image-wrapper {
  flex: 1;
}
.reason-content {
  flex: 1;
}
.reason-num {
  font-family: var(--font-base);
  color: var(--color-accent);
  font-size: 0.9rem;
  letter-spacing: 0.1em;
  margin-bottom: 15px;
}
.reason-title {
  font-size: 1.4rem;
  font-weight: normal;
  color: var(--color-primary);
  margin-bottom: 20px;
}
.reason-desc {
  color: var(--color-text-light);
  font-size: 0.95rem;
}

@media (max-width: 768px) {
  .reason-item, .reason-item.reverse {
    flex-direction: column;
    gap: 30px;
    margin-bottom: 60px;
  }
}

/* ==================================================
   Track Record Section
================================================== */
.track-record-section {
  padding: 100px 0;
  background-color: var(--color-bg-gray); 
}

.track-record-lead {
  text-align: center;
  margin-bottom: 50px;
  color: var(--color-text);
  line-height: 1.8;
}

.track-record-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
}

.track-record-card {
  background: #FFFFFF;
  border: 1px solid var(--color-border);
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.track-record-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.08);
}

.track-record-img {
  aspect-ratio: 4 / 3;
  background: #e5e7eb;
  position: relative;
  overflow: hidden;
}

.track-record-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.track-record-card:hover .track-record-img img {
  transform: scale(1.05);
}

.track-record-info {
  padding: 25px 20px;
  text-align: center;
}

.track-record-tag {
  display: inline-block;
  font-size: 0.75rem;
  color: var(--color-accent);
  border: 1px solid var(--color-accent);
  padding: 4px 12px;
  margin-bottom: 12px;
  letter-spacing: 0.1em;
}

.track-record-name {
  font-size: 1.15rem;
  color: var(--color-primary);
  line-height: 1.5;
  font-weight: 500;
  font-family: var(--font-title);
}

@media (max-width: 768px) {
  .track-record-section { padding: 70px 0; }
}

/* ==================================================
   Media Section
================================================== */
.media-section {
  padding: 100px 0;
  background-color: #FFFFFF;
}

.media-wrapper {
  display: flex;
  justify-content: center;
  gap: 30px;
  margin-top: 40px;
}

.media-item {
  flex: 1;
  max-width: 420px;
  text-align: center;
}

.media-img-wrapper {
  background: #FFFFFF;
  border: 1px solid var(--color-border);
  padding: 8px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
  margin-bottom: 20px;
  aspect-ratio: 16 / 9; 
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.media-img-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover; 
}

.media-text {
  font-family: var(--font-base);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-primary);
  display: block;
}

.media-text::after {
  content: "";
  display: block;
  width: 30px;
  height: 2px;
  background-color: var(--color-accent);
  margin: 10px auto 0;
}

@media (max-width: 768px) {
  .media-wrapper {
    flex-direction: column;
    align-items: center;
    gap: 40px;
  }
  .media-item { width: 100%; }
}

/* ==================================================
   6. Voice Section
================================================== */
.voice-section {
  padding: 100px 0;
  background: var(--color-bg-gray);
}
.voice-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
}
.voice-card {
  background: #FFFFFF;
  padding: 40px 30px;
  border: 1px solid var(--color-border);
}

/* アバター画像用のプレースホルダー設定 */
.voice-avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background-color: var(--color-border); /* 画像がない時のグレー背景 */
  margin-bottom: 15px;
  background-size: cover;
  background-position: center;
}

.voice-meta {
  margin-bottom: 15px;
}
.voice-job {
  font-size: 0.85rem;
  color: var(--color-text-light);
  border-bottom: 1px solid var(--color-accent);
  padding-bottom: 5px;
}
.voice-title {
  font-size: 1.1rem;
  font-weight: normal;
  color: var(--color-primary);
  margin-bottom: 15px;
}
.voice-text {
  font-size: 0.9rem;
  color: var(--color-text-light);
}

/* ==================================================
   7. Flow Section
================================================== */
.step-section {
  padding: 100px 0;
  background: #FFFFFF;
}
.step-flow {
  max-width: 700px;
  margin: 0 auto;
}
.step-item {
  display: flex;
  margin-bottom: 30px;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 30px;
}
.step-num {
  color: var(--color-accent);
  font-size: 1.5rem;
  width: 80px;
  font-family: var(--font-title);
}
.step-content {
  flex: 1;
}
.step-title {
  font-size: 1.1rem;
  margin-bottom: 10px;
  color: var(--color-primary);
  font-weight: normal;
}
.step-text {
  font-size: 0.9rem;
  color: var(--color-text-light);
}

/* ==================================================
   FAQ Section
================================================== */
.faq-section {
  padding: 100px 0;
  background-color: var(--color-bg-gray);
}

.faq-list {
  max-width: 800px;
  margin: 0 auto;
}

.faq-item {
  background: #FFFFFF;
  border: 1px solid var(--color-border);
  margin-bottom: 15px;
  transition: all 0.3s ease;
}

.faq-item summary::-webkit-details-marker {
  display: none;
}
.faq-item summary {
  display: block;
  list-style: none;
  cursor: pointer;
  padding: 24px 60px 24px 30px;
  position: relative;
  font-weight: 500;
  color: var(--color-primary);
  font-size: 1.05rem;
}

.faq-item summary::before,
.faq-item summary::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 30px;
  width: 14px;
  height: 2px;
  background-color: var(--color-accent);
  transition: transform 0.3s ease;
}
.faq-item summary::after {
  transform: rotate(90deg);
}

.faq-item[open] summary::after {
  transform: rotate(0deg);
}
.faq-item[open] summary::before {
  transform: rotate(180deg);
}

.faq-a {
  padding: 0 30px 24px 30px;
  border-top: 1px solid #F0F0F0;
  color: var(--color-text-light);
  font-size: 0.95rem;
  line-height: 1.8;
  animation: fadeInFAQ 0.4s ease forwards;
}

@keyframes fadeInFAQ {
  0% { opacity: 0; transform: translateY(-10px); }
  100% { opacity: 1; transform: translateY(0); }
}

@media (max-width: 768px) {
  .faq-item summary {
    padding: 18px 50px 18px 20px;
    font-size: 0.95rem;
  }
}

/* ==================================================
   Closing Section
================================================== */
.closing-section {
  padding: 120px 0;
  background-color: #FFFFFF;
  text-align: center;
}

.closing-lead {
  font-size: 1.1rem;
  color: var(--color-accent);
  margin-bottom: 20px;
  font-weight: 500;
}

.closing-title {
  font-family: var(--font-title);
  font-size: 2.2rem;
  line-height: 1.5;
  color: var(--color-primary);
  margin-bottom: 50px;
}

.closing-buttons {
  max-width: 450px;
  margin: 0 auto 20px;
}

@media (max-width: 768px) {
  .closing-title { font-size: 1.6rem; }
}

/* ==================================================
   Footer Section
================================================== */
.footer-section {
  background: var(--color-primary); /* フッターは引き締めるためにネイビーに変更 */
  color: #fff;
  padding: 80px 0 30px;
}

.footer-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 60px;
}

.footer-logo {
  font-family: var(--font-title);
  font-size: 1.4rem;
  color: #fff;
  margin-bottom: 15px;
}

.footer-logo-jp {
  font-size: 0.9rem;
  font-family: var(--font-base);
  color: var(--color-accent);
}

.footer-desc {
  font-size: 0.85rem;
  color: #ccc;
  line-height: 1.8;
}

.footer-links ul {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.footer-links a {
  font-size: 0.9rem;
  color: #fff;
  transition: color 0.3s;
}

.footer-links a:hover {
  color: var(--color-accent);
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding-top: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.8rem;
  color: #ccc;
}

.footer-legal {
  display: flex;
  gap: 25px;
}

.footer-legal a:hover {
  text-decoration: underline;
}

@media (max-width: 768px) {
  .footer-top { flex-direction: column; gap: 40px; text-align: center; align-items: center; }
  .footer-bottom { flex-direction: column; gap: 20px; }
  .footer-legal { justify-content: center; }
}

/* ==================================================
   FV Section - 明るさ調整 & SP人物配置
================================================== */
/* 背景を沈めて中央の文字を浮かせるグラデーション（★明るく修正） */
.fv-bg::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* rgbaの値を小さくして、元の写真の明るさを活かす（0.3→0.1, 0.8→0.6） */
  background: radial-gradient(circle, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.6) 100%);
}

@media (max-width: 768px) {
  .fv-bg {
    /* ★SPだと中央揃えで右の人物が切れてしまうため、表示位置を右寄りに固定 */
    background-position: 80% center; 
  }
}

/* ==================================================
   追従LINEボタン（SP専用）
================================================== */
.sticky-btn-wrapper {
  display: none; /* PCでは非表示 */
}

@media (max-width: 768px) {
  /* 追従ボタンにフッター等が隠れないよう、bodyの最下部に余白を追加 */
  body {
    padding-bottom: 90px; 
  }
  
  .sticky-btn-wrapper {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    /* 後ろが少し透けるすりガラス風の背景枠 */
    background: rgba(255, 255, 255, 0.85); 
    backdrop-filter: blur(10px);
    padding: 12px 15px;
    z-index: 9999; /* 最前面に固定 */
    border-top: 1px solid var(--color-border);
    box-shadow: 0 -4px 15px rgba(0, 0, 0, 0.05);
  }

  /* ボタン本体：ハイメンズカラー（ネイビー×ゴールド） */
  .sticky-line-btn {
    display: block;
    width: 100%;
    background: var(--color-primary); /* ネイビー */
    color: #FFFFFF;
    text-align: center;
    padding: 16px 0;
    font-size: 1.1rem;
    font-weight: 700;
    border-radius: 6px;
    border: 1px solid var(--color-accent); /* ゴールドの枠線 */
    letter-spacing: 0.1em;
    box-shadow: 0 4px 10px rgba(15, 23, 42, 0.3);
    transition: transform 0.2s ease;
  }

  /* タップした時に少し凹むアニメーション（スマホ特有の操作感） */
  .sticky-line-btn:active {
    transform: scale(0.97); 
  }
}
/* ==================================================
   Closing Section (浮き解消・SP最適化版)
================================================== */
.closing-section {
  padding: 80px 0; /* 余白を少し詰めて間延びを解消 */
  background-color: var(--color-bg-gray); /* 背景をグレーにしてセクションを区切る */
  text-align: center;
}

.closing-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
}

/* コンテンツ全体をカード化して「浮いてる感」をなくす */
.closing-content {
  background: #FFFFFF;
  padding: 60px 40px;
  border-radius: 12px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04); /* 柔らかい影で接地させる */
  border: 1px solid var(--color-border);
}

.closing-lead {
  font-size: 1rem;
  color: var(--color-accent); 
  margin-bottom: 15px;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.closing-title {
  font-family: var(--font-title);
  font-size: 1.8rem;
  line-height: 1.6;
  color: var(--color-primary);
  margin-bottom: 40px;
}

.closing-buttons {
  max-width: 320px; /* ボタンが横に広がりすぎないように制限 */
  margin: 0 auto;
}

/* クロージング専用のスマートなボタン */
.closing-line-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  background: var(--color-primary);
  color: #FFFFFF;
  width: 100%;
  padding: 16px 0; /* paddingを絞ってコンパクトに */
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-decoration: none;
  border-radius: 50px; /* 角丸にしてモダンな押しやすさを演出 */
  border: 2px solid var(--color-primary);
  transition: all 0.3s ease;
}

.closing-line-btn .btn-icon {
  font-size: 1.2rem;
}

.closing-line-btn:hover {
  background: #FFFFFF;
  color: var(--color-primary);
  transform: translateY(-2px);
}

/* ==================================================
   Responsive (Mobile Optimize)
================================================== */
@media (max-width: 768px) {
  .closing-section {
    padding: 60px 0;
  }
  .closing-content {
    padding: 40px 20px; /* スマホでは内側の余白を少し狭く */
    border-radius: 8px;
    border-left: none;
    border-right: none; /* スマホ画面幅いっぱいに広げる場合は左右ボーダーを消すのもアリ */
  }
  .closing-title { 
    font-size: 1.3rem; 
    margin-bottom: 30px;
  }
  .closing-line-btn {
    font-size: 1rem;
    padding: 14px 0;
  }
}

/* ==================================================
   Access Section
================================================== */
.access-section {
  padding: 100px 0;
  background-color: #FFFFFF;
}

.access-container {
  max-width: 800px; /* マップが横に広がりすぎないように制限 */
  margin: 0 auto;
  padding: 0 20px;
}

.access-card {
  background: #FFFFFF;
  border: 1px solid var(--color-border);
  border-radius: 12px;
  padding: 40px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04); /* クロージング部分と同じ柔らかい影 */
}

.office-name {
  font-family: var(--font-title);
  font-size: 1.5rem;
  color: var(--color-primary);
  margin-bottom: 25px;
  text-align: center;
  line-height: 1.5;
}

.office-name span {
  display: block;
  font-size: 1rem;
  color: var(--color-text-light);
  font-family: var(--font-base);
  margin-top: 5px;
}

.google-map {
  margin-bottom: 30px;
  border-radius: 8px;
  overflow: hidden; /* iframeの角丸を強制的に効かせる */
  border: 1px solid var(--color-border); /* マップの周りに薄い枠線 */
}

.google-map iframe {
  display: block; /* iframe特有の下部の謎の隙間を消す */
}

.office-info {
  text-align: center;
}

.office-info .address {
  font-size: 1.05rem;
  color: var(--color-text);
  margin-bottom: 12px;
  line-height: 1.6;
}

.office-info .hours {
  font-size: 0.95rem;
  color: var(--color-accent); /* ゴールドで営業時間を強調 */
  font-weight: 700;
  letter-spacing: 0.05em;
}

/* ==================================================
   Responsive (Mobile Optimize)
================================================== */
@media (max-width: 768px) {
  .access-section {
    padding: 80px 0;
  }
  .access-card {
    padding: 30px 20px;
  }
  .office-name {
    font-size: 1.3rem;
  }
  .google-map iframe {
    height: 300px; /* スマホではマップの高さを抑えてスクロールしやすくする */
  }
  .office-info .address {
    font-size: 0.95rem;
  }
}

/* ==================================================
   共通CTAボタンデザイン（追従 & クロージング共通）
================================================== */
.common-cta-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 18px 0;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-decoration: none;
  border-radius: 8px; /* 少し角を残したハイクラスな角丸 */
  transition: all 0.3s ease;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

/* LINE・電話共通：ハイメンズネイビー背景 + ゴールド枠 */
.line-color, .tel-color {
  background: var(--color-primary);
  color: #FFFFFF;
  border: 1px solid var(--color-accent);
}

.common-cta-btn:hover {
  background: var(--color-accent);
  color: var(--color-primary);
  transform: translateY(-3px);
}

.common-cta-btn .btn-icon {
  font-size: 1.3rem;
}

/* ==================================================
   Closing Section レイアウト調整
================================================== */
.closing-section {
  padding: 100px 0;
  background-color: var(--color-bg-gray);
}

.closing-content {
  background: #FFFFFF;
  padding: 60px 40px;
  border-radius: 15px;
  border: 1px solid var(--color-border);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.04);
}

.closing-buttons {
  max-width: 400px; /* 2つのボタンを収めるために少し広げました */
  margin: 0 auto;
  display: flex;
  flex-direction: column; /* 縦に並べて押しやすさを確保 */
  gap: 15px;
}

/* ==================================================
   追従ボタン（SP）のクラスも共通クラスへ差し替え
================================================== */
@media (max-width: 768px) {
  .sticky-line-btn {
    /* common-cta-btnと同じスタイルが当たるようにHTML側でクラスを振ってください */
    padding: 16px 0; 
    font-size: 1rem;
  }
  
  .closing-title {
    font-size: 1.4rem;
    margin-bottom: 35px;
  }
}

/* 電話ボタン：ラグジュアリーローズ + ピンクゴールド枠 */
.tel-color {
  background: #8B1C31; /* 高級感のある深いローズピンク */
  color: #FFFFFF;
  border: 1px solid #E5A9B4; /* なじみの良いピンクゴールド系の枠線 */
}

.tel-color:hover {
  background: #FFFFFF;
  color: #8B1C31;
  border: 1px solid #8B1C31;
}

/* ==================================================
   PC Footer (修正版：配置を最適化)
================================================== */
.footer-section { background: var(--color-primary); color: #fff; padding: 80px 0 40px; }
.footer-container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.footer-top { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 60px; }
.footer-logo { font-family: var(--font-title); font-size: 1.5rem; margin-bottom: 10px; }
.footer-desc { color: #ccc; font-size: 0.85rem; }
.footer-links { display: flex; gap: 30px; list-style: none; }
.footer-links a { color: #fff; text-decoration: none; font-size: 0.9rem; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); padding-top: 30px; display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; color: #ccc; }
.footer-legal { display: flex; gap: 20px; list-style: none; }

@media (max-width: 768px) {
  .footer-top { flex-direction: column; align-items: center; text-align: center; gap: 40px; }
  .footer-links { flex-direction: column; gap: 15px; align-items: center; }
  .footer-bottom { flex-direction: column-reverse; gap: 20px; text-align: center; }
  .footer-legal { justify-content: center; }
}

/* ==================================================
   SNS (Official X) Section
================================================== */
.sns-section {
  padding: 80px 0;
  /* 前後のセクションとメリハリをつけるためネイビー背景を採用 */
  background-color: var(--color-primary); 
  color: #FFFFFF;
}

.sns-container {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ラグジュアリーなすりガラス風カード */
.sns-content-wrapper {
  display: flex;
  align-items: center;
  gap: 50px;
  background: rgba(255, 255, 255, 0.03); 
  border: 1px solid rgba(212, 176, 123, 0.2); /* 薄いゴールドの枠線 */
  border-radius: 15px;
  padding: 50px;
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.2);
}

.sns-text-box {
  flex: 1;
}

.sns-text-box .section-en {
  color: var(--color-accent);
  margin-bottom: 15px;
  font-weight: 700;
  letter-spacing: 0.1em;
}

.sns-title {
  font-family: var(--font-title);
  font-size: 1.8rem;
  line-height: 1.4;
  margin-bottom: 20px;
}

.sns-highlight {
  font-size: 2.8rem;
  color: var(--color-accent); /* Xの部分をゴールドで強調 */
}

.sns-desc {
  color: #cccccc;
  font-size: 0.95rem;
  line-height: 1.8;
  margin-bottom: 35px;
}

/* X公式風のブラックボタン */
.sns-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: #000000;
  color: #FFFFFF;
  padding: 16px 40px;
  border-radius: 50px;
  font-weight: 700;
  letter-spacing: 0.05em;
  border: 1px solid #333333;
  transition: all 0.3s ease;
  text-decoration: none;
}

.sns-btn .btn-icon {
  font-size: 1.3rem;
  font-weight: normal; /* アイコンをスッキリ見せる */
}

.sns-btn:hover {
  background: #222222;
  transform: translateY(-2px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.4);
}

.sns-image-box {
  flex: 1;
  border-radius: 10px;
  overflow: hidden;
  /* 画像自体も少し浮かせる */
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4); 
}

.sns-image-box img {
  width: 100%;
  height: auto;
  display: block;
}

/* ==================================================
   Responsive (Mobile Optimize)
================================================== */
@media (max-width: 768px) {
  .sns-section {
    padding: 60px 0;
  }
  .sns-content-wrapper {
    flex-direction: column;
    padding: 30px 20px;
    gap: 30px;
  }
  .sns-text-box {
    text-align: center;
  }
  .sns-title {
    font-size: 1.5rem;
  }
  .sns-highlight {
    font-size: 2.2rem;
  }
  .sns-desc {
    text-align: left; /* 説明文は左揃えの方が見やすい */
    margin-bottom: 25px;
  }
  .sns-btn {
    width: 100%;
    padding: 14px 0;
  }
}

/* ==================================================
   Voice Section (Swiperスライダー版)
================================================== */
.voice-section {
  padding: 100px 0;
  background: var(--color-bg-gray);
  overflow: hidden; /* スライダーが画面外にはみ出さないようにする */
}

.voice-container {
  max-width: 1200px;
  margin: 0 auto;
  /* スマホの時に画面端までスライダーが伸びるように左右のpaddingは外す */
  padding: 0; 
}

/* ヘッダー部分はpaddingを戻す */
.voice-container .section-header {
  padding: 0 20px;
}

.section-sub {
  margin-top: 15px;
  color: var(--color-text-light);
  font-size: 0.95rem;
}

/* スライダー全体の余白調整 */
.voice-swiper {
  padding-bottom: 50px !important; /* ドットのための下部余白 */
  margin-top: 40px;
}

/* 画像カードの装飾 */
.voice-x-item {
  background: #FFFFFF;
  border: 1px solid var(--color-border);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  /* スライドが中央（アクティブ）じゃないときは少し透明にして立体感を出す演出 */
  opacity: 0.5;
  transition: all 0.3s ease;
  transform: scale(0.9);
}

/* 中央（アクティブ）のスライドだけハッキリ見せて大きくする */
.swiper-slide-active .voice-x-item {
  opacity: 1;
  transform: scale(1);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

.voice-x-item img {
  width: 100%;
  height: auto;
  display: block;
}

/* ページネーション（ドット）の色をハイメンズカラー（ネイビー）に変更 */
.swiper-pagination-bullet {
  background: var(--color-text-light);
  opacity: 0.5;
}
.swiper-pagination-bullet-active {
  background: var(--color-primary);
  opacity: 1;
}

/* ==================================================
   Responsive (Mobile Optimize)
================================================== */
@media (max-width: 768px) {
  .voice-section {
    padding: 70px 0;
  }
  .section-sub {
    font-size: 0.85rem;
  }
}

/* ==================================================
   FV Section (シンプル＆クリーンな王道デザイン)
================================================== */
.fv-text-block {
  color: #fff;
  text-align: center;
}

/* 白文字 ＋ 1pxの黒フチ ＋ 影 */
.fv-lead {
  font-size: clamp(14px, 3vw, 18px);
  font-weight: 700;
  margin-bottom: 5px;
  letter-spacing: 0.1em;
  text-shadow: 
    1px 1px 0 #000, -1px -1px 0 #000,
   -1px 1px 0 #000,  1px -1px 0 #000,
    0 4px 6px rgba(0, 0, 0, 0.6);
}

/* 白文字 ＋ 2pxの黒フチ ＋ 影 */
.fv-title {
  font-family: var(--font-title);
  font-size: clamp(24px, 5vw, 40px);
  line-height: 1.3;
  margin-bottom: 20px;
  font-weight: 700;
  text-shadow: 
    2px 2px 0 #000, -2px -2px 0 #000,
   -2px 2px 0 #000,  2px -2px 0 #000,
    0px 2px 0 #000,  0px -2px 0 #000,
   -2px 0px 0 #000,  2px 0px 0 #000,
    0 6px 10px rgba(0, 0, 0, 0.6);
}

/* メインタイトルはさらにフチを太く（3px）して画像を再現 */
.fv-title-main {
  display: block;
  font-size: clamp(40px, 8vw, 70px);
  margin: 5px 0;
  letter-spacing: 0.05em;
  text-shadow: 
    3px 3px 0 #000, -3px -3px 0 #000,
   -3px 3px 0 #000,  3px -3px 0 #000,
    0px 3px 0 #000,  0px -3px 0 #000,
   -3px 0px 0 #000,  3px 0px 0 #000,
    0 8px 15px rgba(0, 0, 0, 0.7);
}

/* --- クリーンな白バッジ（3つ並び） --- */
.fv-badges {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-bottom: 30px;
}

.fv-badge-clean {
  background: #ffffff;
  color: var(--color-primary); /* ネイビー文字 */
  border: 1px solid var(--color-primary);
  border-radius: 8px; /* 少し角丸にして柔らかさを出す */
  padding: 10px 20px;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.4;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
  text-shadow: none; /* バッジ内の黒フチは削除 */
}

/* 説明文 */
.fv-desc {
  font-size: clamp(14px, 2.5vw, 16px);
  line-height: 1.8;
  font-weight: 700;
  margin-bottom: 35px;
  text-shadow: 
    1px 1px 0 #000, -1px -1px 0 #000,
   -1px 1px 0 #000,  1px -1px 0 #000,
    0 4px 6px rgba(0, 0, 0, 0.6);
}

/* --- 画像と同じネイビーの丸角ボタン --- */
.fv-navy-btn {
  display: inline-block;
  background: var(--color-primary); /* ネイビー */
  color: #fff;
  padding: 18px 70px;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 50px; /* ピル型（丸角） */
  text-decoration: none;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.5);
  border: 2px solid rgba(255, 255, 255, 0.2); /* うっすら白いフチで高級感 */
  transition: all 0.3s ease;
}

.fv-navy-btn:hover {
  background: #1a233a; /* ホバーで少し明るく */
  transform: translateY(-3px);
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.6);
}

/* ==================================================
   SP（スマホ）専用の調整
================================================== */
@media (max-width: 768px) {
  .fv-section { padding-top: 70px; }
  
  /* 文字をギュッと詰める */
  .fv-title { font-size: 22px; }
  .fv-title-main { font-size: 42px; margin: 0; line-height: 1.1; }
  
  /* スマホではバッジを横一列に収めるために微調整 */
  .fv-badges { 
    gap: 5px; 
    margin-top: 15px; 
  }
  .fv-badge-clean { 
    padding: 8px 5px; 
    font-size: 0.75rem; 
    width: 32%; /* 3つがピッタリ横に並ぶようにする */
  }
  
  .fv-desc { font-size: 12px; margin-bottom: 25px; }
  
  /* ボタンもスマホ幅に合わせる */
  .fv-navy-btn { 
    width: 90%; 
    padding: 16px 0; 
    font-size: 1.1rem; 
  }
}
/* ==================================================
   FV Section (レイアウト＆背景)
================================================== */
.fv-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
}

.fv-bg {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  background: url('../img/fv-bg.jpg') center/cover no-repeat; /* 背景画像へのパス */
  z-index: 0;
}

/* PC：左右分割レイアウト */
.fv-container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1100px; /* 画像のバランスに合わせて幅を調整 */
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center; 
  justify-content: space-between;
}

/* 左側：女の子 */
.fv-left {
  width: 42%;
  display: flex;
  align-items: flex-end;
}

.fv-girl-img {
  width: 100%;
  height: auto;
  display: block;
  /* 画像を下にくっつける微調整が必要な場合は margin-bottom などを設定 */
}

/* 右側：テキストエリア */
.fv-right {
  width: 58%;
  text-align: center;
  padding-bottom: 20px;
}

/* ================== テキスト（白文字＋強烈な黒フチ） ================== */
.fv-text-block {
  color: #fff;
}

.fv-lead {
  font-size: clamp(14px, 2.5vw, 18px);
  font-weight: 700;
  margin-bottom: 10px;
  letter-spacing: 0.1em;
  text-shadow: 
    1px 1px 0 #000, -1px -1px 0 #000, -1px 1px 0 #000, 1px -1px 0 #000,
    0 4px 6px rgba(0,0,0,0.6);
}

.fv-title {
  font-family: var(--font-title, sans-serif); /* 力強いゴシック推奨 */
  font-size: clamp(24px, 4vw, 36px);
  line-height: 1.4;
  margin-bottom: 25px;
  font-weight: 900;
  text-shadow: 
    2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000,
    0px 2px 0 #000,  0px -2px 0 #000, -2px 0px 0 #000, 2px 0px 0 #000,
    0 6px 10px rgba(0,0,0,0.7);
}

.fv-title-main {
  display: block;
  font-size: clamp(40px, 6vw, 64px);
  margin: 5px 0;
  letter-spacing: 0.05em;
  text-shadow: 
    3px 3px 0 #000, -3px -3px 0 #000, -3px 3px 0 #000, 3px -3px 0 #000,
    0px 3px 0 #000,  0px -3px 0 #000, -3px 0px 0 #000, 3px 0px 0 #000,
    0 8px 15px rgba(0,0,0,0.8);
}

.fv-desc {
  font-size: clamp(13px, 2vw, 16px);
  line-height: 1.8;
  font-weight: 700;
  margin-bottom: 30px;
  text-shadow: 
    1px 1px 0 #000, -1px -1px 0 #000, -1px 1px 0 #000, 1px -1px 0 #000,
    0 4px 6px rgba(0,0,0,0.6);
}

/* ================== バッジ（白背景×ゴールド翼×ネイビー文字） ================== */
.fv-badges {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin-bottom: 30px;
}

.fv-badge-wreath {
  display: flex;
  align-items: center;
  gap: 8px;
  background: #ffffff;
  border-radius: 50px; /* 画像のような楕円形 */
  padding: 10px 18px;
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.4);
}

.wing {
  color: #c9a05b; /* 高級感のあるゴールド */
  width: 22px;
  height: 36px;
}

.wing-right {
  transform: scaleX(-1); 
}

.wreath-text {
  color: #1a233a; /* 深いネイビー */
  font-size: 0.9rem;
  font-weight: 900;
  line-height: 1.4;
  text-align: center;
}

/* ================== ボタン（ネイビー×白フチ×LINEアイコン） ================== */
.fv-navy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #1a233a; /* ネイビー */
  color: #ffffff;
  padding: 16px 45px;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 50px;
  border: 2px solid #ffffff; /* 白フチ */
  text-decoration: none;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.6);
  transition: transform 0.2s;
}

.fv-navy-btn:hover {
  transform: translateY(-3px);
}

/* ボタン右側の小さなLINEバッジ */
.line-icon-badge {
  background: #ffffff;
  color: #1a233a; /* 文字はネイビー */
  font-size: 0.65rem;
  font-weight: 900;
  border-radius: 50%;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 15px; /* テキストとの隙間 */
}

/* ==================================================
   SP（スマホ）専用のレイアウト調整
================================================== */
@media (max-width: 768px) {
  /* スマホ時は縦積み（上がテキスト、下が女の子）に変更 */
  .fv-container {
    flex-direction: column;
    justify-content: flex-start;
    padding-top: 90px;
  }
  
  .fv-right { width: 100%; margin-bottom: 20px; }
  .fv-left { width: 85%; margin: 0 auto; }
  
  /* スマホは文字の黒フチを少し細くして読みやすく */
  .fv-title { font-size: 22px; text-shadow: 1px 1px 0 #000, -1px -1px 0 #000, -1px 1px 0 #000, 1px -1px 0 #000, 0 4px 6px rgba(0,0,0,0.6); }
  .fv-title-main { font-size: 38px; text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0px -2px 0 #000, -2px 0px 0 #000, 2px 0px 0 #000, 0 6px 10px rgba(0,0,0,0.7); }
  
  .fv-badges { gap: 8px; flex-wrap: wrap; }
  .fv-badge-wreath { width: 31%; padding: 8px 4px; border-radius: 12px; } /* スマホは丸角四角に */
  .wing { width: 14px; height: 26px; }
  .wreath-text { font-size: 0.7rem; }
  
  .fv-desc { font-size: 13px; margin-bottom: 25px; }
  
  .fv-navy-btn { width: 100%; font-size: 1.2rem; padding: 15px 0; }
}