/* ===== 冬割キャンペーンセクション（雪アニメ付きVer.） ===== */
.winter-campaign {
  background: linear-gradient(to bottom right, #f7f9fc, #ffffff);
  padding: 100px 0;
  position: relative;
  overflow: hidden;
}

/* 雪の装飾背景 */
.winter-campaign::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url('https://kyoto-hatoya.jp/wp-content/themes/hatoya-zuihokaku/images/common/snow_pattern.svg');
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 0.05;
  z-index: 0;
}

/* 見出しエリア */
.winter-heading {
  text-align: center;
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin: 0 auto;
}

/* タイトル */
.winter-subtitle {
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 2.4rem;
  font-weight: 700;
  color: #1e2d4d;
  letter-spacing: 0.1em;
  margin-bottom: 0.5em;
  position: relative;
  display: inline-block;
}

.winter-subtitle .en {
  display: block;
  font-size: 0.9rem;
  color: #7a849a;
  letter-spacing: 0.2em;
  margin-top: 4px;
}

.winter-subtitle .snowflake {
  position: absolute;
  top: -15px;
  right: -25px;
  font-size: 1.2rem;
  color: #a9bdd7;
  opacity: 0.7;
  animation: snowTwinkle 3s ease-in-out infinite;
}

/* 下線 */
.winter-subtitle::after {
  content: "";
  display: block;
  width: 100px;
  height: 2.5px;
  margin: 15px auto 0;
  background: linear-gradient(90deg, #bcc4d6, #aab0be);
  border-radius: 2px;
  box-shadow: 0 2px 8px rgba(160, 170, 190, 0.4);
}

/* リード文 */
.lead {
  font-size: 1.15rem;
  line-height: 1.9;
  color: #555;
  max-width: 780px;
  margin: 20px auto 0;
  padding: 0 20px;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
}

/* 下部の光 */
.winter-campaign::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 85%;
  height: 160px;
  background: radial-gradient(circle at center, rgba(210, 225, 250, 0.3), transparent 70%);
  z-index: 1;
}

/* ❄ 雪アニメーション要素 */
.snow {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  background-image:
    radial-gradient(white 1.5px, transparent 1.5px),
    radial-gradient(white 1px, transparent 1px),
    radial-gradient(white 2px, transparent 2px);
  background-size: 80px 80px, 100px 100px, 120px 120px;
  background-position: 0 0, 40px 20px, 20px 40px;
  animation: snowFall 20s linear infinite;
  opacity: 0.7;
  z-index: 1;
}

/* 雪の動き */
@keyframes snowFall {
  0% {
    background-position: 0 0, 40px 20px, 20px 40px;
  }
  100% {
    background-position: 0 800px, 40px 820px, 20px 840px;
  }
}

/* 結晶の光アニメ */
@keyframes snowTwinkle {
  0%, 100% { opacity: 0.7; transform: rotate(0deg) scale(1); }
  50% { opacity: 1; transform: rotate(10deg) scale(1.1); }
}

/* スマホ対応 */
@media (max-width: 768px) {
  .winter-subtitle {
    font-size: 1.7rem;
  }
  .winter-subtitle .en {
    font-size: 0.8rem;
  }
  .lead {
    font-size: 1rem;
    line-height: 1.8;
  }
  .winter-campaign {
    padding: 70px 0;
  }
  .winter-subtitle .snowflake {
    right: -10px;
    top: -10px;
  }
}

/* ===============================
   冬キャンペーンセクション（中央一体化）
   =============================== */
.winter-campaign {
  text-align: center;
  padding: 60px 0 0; /* 下の画像とつながるように下パディングを0に */
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  color: #2b2b2b;
  background: none;
}

.winter-campaign .inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
}

/* 見出しブロック */
.winter-heading {
  margin-bottom: 20px; /* 画像との間をギュッと詰める */
}

/* タイトル */
.winter-subtitle {
  display: inline-block;
  position: relative;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #2f2f2f;
  margin-bottom: 0.4em;
  line-height: 1.4;
}

/* 下ライン */
.winter-subtitle::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 2px;
  background: linear-gradient(90deg, transparent, #aaa, transparent);
}

/* 日本語・英語タイトル */
.winter-subtitle .jp {
  display: block;
  font-size: 1.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}

.winter-subtitle .en {
  display: block;
  font-size: 0.9rem;
  color: #888;
  letter-spacing: 0.15em;
  margin-top: 4px;
}

.winter-subtitle .snowflake {
  display: inline-block;
  font-size: 1.2rem;
  color: #a0a0a0;
  margin-left: 6px;
}

/* リード文 */
.winter-heading .lead {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  font-size: 1.05rem;
  line-height: 1.9;
  color: #333;
  margin: 0 auto;
  max-width: 700px;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 8px;
  padding: 1.4em 2em;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(5px);
}

/* 画像セクションとの距離を統一・一体化 */
#hotspringContent1 {
  margin-top: 0;
  padding-top: 10px; /* ← タイトルとの繋がりを自然に見せる最適値 */
}

@media (min-width: 769px) {
  .winter-campaign {
    background: #fdfdfd !important; /* わずかに暖かみのある白 */
  }
}


/* ===============================
   スマホ対応
   =============================== */
@media (max-width: 768px) {
  .winter-campaign {
    padding: 40px 0 0;
  }

  .winter-heading {
    margin-bottom: 16px;
  }

  .winter-subtitle .jp {
    font-size: 1.6rem;
  }

  .winter-subtitle .en {
    font-size: 0.8rem;
  }

  .winter-heading .lead {
    font-size: 0.95rem;
    padding: 1.2em 1.4em;
  }
}

/* ===============================
   冬キャンペーンセクション（中央一体化）
   =============================== */
.winter-campaign {
  text-align: center;
  padding: 60px 0 0; /* 下の画像とつながるように下パディングを0に */
  font-family: "Noto Serif JP", "Yu Mincho", serif;
  color: #2b2b2b;
  background: none;
}

.winter-campaign .inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
}

/* 見出しブロック */
.winter-heading {
  margin-bottom: 20px; /* 画像との間をギュッと詰める */
}

/* タイトル */
.winter-subtitle {
  display: inline-block;
  position: relative;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #2f2f2f;
  margin-bottom: 0.4em;
  line-height: 1.4;
}

/* 下ライン */
.winter-subtitle::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 2px;
  background: linear-gradient(90deg, transparent, #aaa, transparent);
}

/* 日本語・英語タイトル */
.winter-subtitle .jp {
  display: block;
  font-size: 1.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
}

.winter-subtitle .en {
  display: block;
  font-size: 0.9rem;
  color: #888;
  letter-spacing: 0.15em;
  margin-top: 4px;
}

.winter-subtitle .snowflake {
  display: inline-block;
  font-size: 1.2rem;
  color: #a0a0a0;
  margin-left: 6px;
}

/* リード文 */
.winter-heading .lead {
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  font-size: 1.05rem;
  line-height: 1.9;
  color: #333;
  margin: 0 auto;
  max-width: 700px;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 8px;
  padding: 1.4em 2em;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(5px);
}

/* 画像セクションとの距離を統一・一体化 */
#hotspringContent1 {
  margin-top: 0;
  padding-top: 10px; /* ← タイトルとの繋がりを自然に見せる最適値 */
}

/* ===============================
   スマホ対応
   =============================== */
@media (max-width: 768px) {
  .winter-campaign {
    padding: 40px 0 0;
  }

  .winter-heading {
    margin-bottom: 16px;
  }

  .winter-subtitle .jp {
    font-size: 1.6rem;
  }

  .winter-subtitle .en {
    font-size: 0.8rem;
  }

  .winter-heading .lead {
    font-size: 0.95rem;
    padding: 1.2em 1.4em;
  }
}

/* ===============================
   冬キャンペーンと画像ボックスの隙間を詰める
   =============================== */

/* キャンペーンセクション下の余白を削る */
.winter-campaign {
  padding-bottom: 10px; /* ← 以前 40〜60px 程度だった場合、大幅に減らす */
  margin-bottom: 0;     /* 念のためマージンもリセット */
}

/* 温泉コンテンツの上余白を削る */
#hotspringContent1 {
  margin-top: 0;        /* セクション間の間隔を消す */
  padding-top: 0;       /* 内側余白もゼロにして密着 */
}

/* ===============================
   冬キャンペーンセクション：背景リセット
   =============================== */
.winter-campaign {
  background: none !important;  /* ← グラデーションを完全削除 */
  background-color: transparent !important; /* 念のため透明に */
}


