/* ==================================================================
   The Big Family Guide to Japan — デザインシステム
   ------------------------------------------------------------------
   色・フォント・余白・立体感の世界観をここで一元管理する。
   配色やトーンを変えたいときは :root のトークンを差し替えるだけ。
   全言語ページ共通。
   ================================================================== */

:root {
  /* ---- カラーパレット ---- */
  --color-primary: #1A3761;        /* 深い青：信頼（航空/ホテル系） */
  --color-primary-dark: #122843;   /* primary のホバー/濃色用 */
  --color-accent: #FF9F1C;         /* オレンジ：アクション/Klook誘導 */
  --color-accent-dark: #F08A00;    /* accent のホバー用 */
  --color-bg: #FFFFFF;             /* ベース背景：白 */
  --color-text: #333333;           /* 本文テキスト */
  --color-subtext: #666666;        /* サブテキスト */
  --color-light: #F4F7F6;          /* 薄いグレー：背景の区切り */

  /* ---- レイアウト幅 ---- */
  --max-width: 1100px;             /* ヘッダー/ナビ/フッターの最大幅 */
  --content-width: 800px;          /* 記事本文の読みやすい最大幅 */

  /* ---- 立体感・形状 ---- */
  --radius: 8px;
  --shadow-soft: 0 10px 30px rgba(0, 0, 0, 0.05);   /* 柔らかい浮き */
  --shadow-hover: 0 16px 36px rgba(0, 0, 0, 0.12);  /* ホバー時の強調 */
  --transition: 0.25s ease;

  /* ---- フォント ---- */
  --font-base: "Noto Sans", "Noto Sans TC", system-ui, -apple-system,
    "Segoe UI", "Hiragino Sans", sans-serif;

  /* ---- ヒーロー背景の青オーバーレイ ---- */
  --hero-overlay: linear-gradient(rgba(26, 55, 97, 0.7), rgba(26, 55, 97, 0.7));
  /* 画像はローカル配置（/assets/images/hero.{jpg,webp}）。差し替えは
     scripts/optimize-hero.mjs で再生成するだけ。 */
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth; /* アンカークリックでスムーズスクロール */
}

body {
  margin: 0;
  font-family: var(--font-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.8; /* 本文：広めの行間で長文でも疲れない */
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
}

/* 見出し共通：太く・行間を詰めて力強く */
h1,
h2,
h3 {
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-primary);
}

/* 中央寄せの共通コンテナ */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
}

/* ==================================================================
   1. ヘッダー（左：ロゴ / 右：言語切替）
   ================================================================== */
.site-header {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(180%) blur(8px);
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.06);
  position: sticky;
  top: 0;
  z-index: 20;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 18px 0;
}

.logo {
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--color-primary);
  text-decoration: none;
  letter-spacing: 0.01em;
}

.lang-switch {
  display: flex;
  gap: 8px;
  font-size: 0.85rem;
}

.lang-switch a {
  text-decoration: none;
  color: var(--color-subtext);
  padding: 6px 12px;
  border-radius: 999px;
  transition: background var(--transition), color var(--transition);
}

.lang-switch a:hover {
  background: var(--color-light);
  color: var(--color-primary);
}

.lang-switch a[aria-current="true"] {
  background: var(--color-primary);
  color: #ffffff;
  font-weight: 700;
}

/* ==================================================================
   2. メインビジュアル（Hero）：背景画像＋青オーバーレイ
   ================================================================== */
.hero {
  position: relative;
  min-height: 78vh;
  display: flex;
  align-items: center;
  text-align: center;
  padding: 80px 0;
  /* 画像が読めない場合のフォールバックに primary を敷く */
  background-color: var(--color-primary);
  /* 上：薄い青オーバーレイ / 下：背景画像（JPEGフォールバック） */
  background-image: var(--hero-overlay), url("/assets/images/hero.jpg");
  background-size: cover;
  background-position: center;
}

/* WebP対応ブラウザはより軽い WebP を使用（デスクトップ：1920幅） */
@supports (background-image: image-set(url("i.webp") type("image/webp"))) {
  .hero {
    background-image: var(--hero-overlay),
      image-set(
        url("/assets/images/hero.webp") type("image/webp"),
        url("/assets/images/hero.jpg") type("image/jpeg")
      );
  }
}

.hero h1 {
  margin: 0 auto 20px;
  max-width: 16ch;
  color: #ffffff;
  font-size: clamp(2.4rem, 6vw, 3.4rem); /* 非常に大きく */
  line-height: 1.25;
  letter-spacing: 0.01em;
}

.hero-sub {
  margin: 0 auto;
  max-width: 620px;
  color: rgba(255, 255, 255, 0.92);
  font-size: 1.15rem;
}

/* ==================================================================
   3. 課題解決ナビ（宿泊 / 移動 / 通信・チケット の3ボックス）
   ================================================================== */
.pain-nav {
  background: var(--color-light);
  padding: 72px 0;
}

.pain-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr); /* PC：4列横並び */
  gap: 28px;
}

.pain-card {
  display: block;
  background: #ffffff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft); /* 枠線ではなく影で境界を表現 */
  padding: 40px 32px;             /* 内部余白を広く */
  text-decoration: none;
  color: var(--color-text);
  transition: transform var(--transition), box-shadow var(--transition);
}

.pain-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}

/* カード背景画像（全言語）：クレジット不要素材に濃いめの白オーバーレイを重ねて
   画像を「うっすら」見せ、見出し・説明文の可読性を保つ。
   画像を外したいカードは、HTML側の修飾クラスを外すだけでよい。 */
.pain-card--hotel,
.pain-card--transport,
.pain-card--sim,
.pain-card--tips {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.pain-card--hotel {
  background-image: linear-gradient(135deg, rgba(255, 255, 255, 0.92),
      rgba(255, 255, 255, 0.82)), url("/assets/images/cards/hotel.webp");
}

.pain-card--transport {
  background-image: linear-gradient(135deg, rgba(255, 255, 255, 0.92),
      rgba(255, 255, 255, 0.82)), url("/assets/images/cards/transport.webp");
}

.pain-card--sim {
  background-image: linear-gradient(135deg, rgba(255, 255, 255, 0.92),
      rgba(255, 255, 255, 0.82)), url("/assets/images/cards/sim.webp");
}

.pain-card--tips {
  background-image: linear-gradient(135deg, rgba(255, 255, 255, 0.92),
      rgba(255, 255, 255, 0.82)), url("/assets/images/cards/tips.webp");
}

.pain-card .pain-card-title {
  margin: 0 0 10px;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
}

.pain-card p {
  margin: 0;
  font-size: 0.97rem;
  color: var(--color-subtext);
}

/* ==================================================================
   4. メインコンテンツ（記事本文：中央寄せ・最大800px）
   ================================================================== */
.content {
  max-width: var(--content-width);
  margin: 0 auto; /* 左右オートで中央寄せ */
  padding: 40px 24px 64px;
}

.content section {
  padding: 60px 0;                 /* 情報の区切りを大きな余白で明確化 */
  scroll-margin-top: 90px;         /* 固定ヘッダー分のアンカー補正 */
}

.content section + section {
  border-top: 1px solid var(--color-light);
}

.content h2 {
  margin: 0 0 20px;
  font-size: 1.9rem;
}

.content h3 {
  margin: 36px 0 14px;
  font-size: 1.25rem;
}

.content p {
  margin: 0 0 20px;
}

/* アフィリエイト開示（PR表記）：本文とは違う「お知らせ」だと分かる見た目に。
   隠していると見なされないよう小さすぎない文字サイズ・薄い背景＋枠線＋アイコン。 */
.affiliate-disclosure {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 28px 0 4px;
  padding: 14px 18px;
  font-size: 0.9rem;
  font-style: italic;
  line-height: 1.65;
  color: var(--color-subtext);
  background: #f8f9fa;
  border: 1px solid #e4e8eb;
  border-radius: var(--radius);
}

.affiliate-disclosure::before {
  content: "ℹ️";
  font-size: 1.05rem;
  line-height: 1.55;
  flex-shrink: 0;
}

/* ==================================================================
   記事ページ（パンくず / 画像 / ボタン）
   ================================================================== */
.breadcrumb {
  margin: 0 0 18px;
  font-size: 0.85rem;
  color: var(--color-subtext);
}

.breadcrumb a {
  color: var(--color-subtext);
  text-decoration: none;
}

.breadcrumb a:hover {
  color: var(--color-primary);
  text-decoration: underline;
}

.breadcrumb .sep {
  margin: 0 6px;
  opacity: 0.6;
}

.breadcrumb [aria-current="page"] {
  color: var(--color-text);
}

/* 記事内の画像（元素材が小さいため等倍上限=拡大しない・中央寄せ） */
.article-figure {
  max-width: 300px; /* 素材の実寸。これ以上引き伸ばさず粗さを防ぐ */
  margin: 30px auto;
}

/* 高解像のリード/ヒーロー画像は本文幅いっぱいまで */
.article-figure--wide {
  max-width: 100%;
}

/* 画像を左右2枚で1段に並べる（縦長写真を小さく横並び） */
.figure-row {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin: 30px 0;
}

.figure-row .article-figure {
  flex: 1 1 0;
  max-width: 200px;
  margin: 0;
}

/* 2枚のサイズを完全に揃える（同じ枠に切り抜き） */
.figure-row .article-figure img {
  height: 200px;
  object-fit: cover;
}

.article-figure img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

.article-figure figcaption {
  margin-top: 8px;
  font-size: 0.83rem;
  color: var(--color-subtext);
  text-align: center;
}

/* Klook アフィリエイト ウィジェット（記事内埋め込み） */
.klook-widget {
  margin: 28px 0;
}

/* CTAの行（中央寄せで強調） */
.article-cta {
  margin: 28px 0;
  text-align: center;
}

/* アフィリエイトCTA：ボタン＋直下のマイクロコピー（補足テキスト） */
.affiliate-wrap {
  margin: 24px 0;
  text-align: center;
}

.affiliate-wrap .microcopy {
  margin: 8px 0 0;
  font-size: 0.8rem;
  color: var(--color-subtext);
}

/* セカンダリボタン（内部リンク用：ネイビー） */
.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0;
  padding: 14px 30px;
  background: var(--color-primary);
  color: #ffffff;
  font-size: 1.02rem;
  font-weight: 700;
  text-decoration: none;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), box-shadow var(--transition),
    background var(--transition);
}

.btn-secondary::after {
  content: "→";
  font-size: 1.15em;
  line-height: 1;
  transition: transform var(--transition);
}

.btn-secondary:hover {
  background: var(--color-primary-dark);
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

.btn-secondary:hover::after {
  transform: translateX(4px);
}

/* ---- アフィリエイトボタン（CTA：オレンジ・浮遊・矢印付き） ---- */
.btn-affiliate {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 12px 0 8px;
  padding: 16px 34px;
  background: var(--color-accent);
  color: #ffffff;
  font-size: 1.08rem;
  font-weight: 700;
  text-decoration: none;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), box-shadow var(--transition),
    background var(--transition);
}

/* 擬似要素で矢印アイコンを付与 */
.btn-affiliate::after {
  content: "→";
  font-size: 1.2em;
  line-height: 1;
  transition: transform var(--transition);
}

.btn-affiliate:hover {
  background: var(--color-accent-dark);
  transform: translateY(-3px); /* 少し浮き上がる */
  box-shadow: var(--shadow-hover);
}

.btn-affiliate:hover::after {
  transform: translateX(4px); /* 矢印が前に進む */
}

/* ==================================================================
   コンタクトフォーム
   ================================================================== */
.page-title {
  margin: 0 0 12px;
  font-size: 2rem;
}

.page-lead {
  margin: 0 0 8px;
  color: var(--color-subtext);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 22px;
  margin-top: 28px;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-field label {
  font-weight: 700;
  font-size: 0.98rem;
  color: var(--color-primary);
}

.form-field input,
.form-field textarea {
  font-family: inherit;
  font-size: 1rem;
  color: var(--color-text);
  padding: 14px 16px;
  background: #ffffff;
  border: 1px solid #d7dedc;
  border-radius: var(--radius);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.form-field input:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(26, 55, 97, 0.12);
}

.form-field textarea {
  min-height: 170px;
  resize: vertical;
}

/* 送信ボタン：アクセントカラー（オレンジ）の目立つスタイル */
.btn-submit {
  align-self: flex-start;
  border: none;
  cursor: pointer;
  background: var(--color-accent);
  color: #ffffff;
  font-family: inherit;
  font-size: 1.08rem;
  font-weight: 700;
  padding: 16px 44px;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition), box-shadow var(--transition),
    background var(--transition);
}

.btn-submit:hover {
  background: var(--color-accent-dark);
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

/* ---- 記事リンクカード（サムネイル＋タイトル） ---- */
.article-card {
  display: flex;
  align-items: stretch;
  margin: 8px 0 0;
  background: #ffffff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  overflow: hidden;
  text-decoration: none;
  color: var(--color-text);
  transition: transform var(--transition), box-shadow var(--transition);
}

.article-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-hover);
}

.article-card img {
  flex-shrink: 0;
  width: 220px;
  height: 150px;
  object-fit: cover;
  display: block;
}

.article-card .card-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  padding: 18px 22px;
}

.article-card .card-content h3 {
  margin: 0;
  font-size: 1.15rem;
}

.article-card .card-more {
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-accent-dark);
}

@media (max-width: 600px) {
  .article-card {
    flex-direction: column; /* スマホ：画像上・テキスト下に縦積み */
  }

  .article-card img {
    width: 100%;
    height: 180px;
  }
}

/* ==================================================================
   5. フッター（コピーライト＋簡易リンク）
   ================================================================== */
.site-footer {
  background: var(--color-primary);
  color: rgba(255, 255, 255, 0.78);
  padding: 48px 0;
  text-align: center;
  font-size: 0.9rem;
}

.footer-links {
  margin-top: 12px;
  display: flex;
  gap: 18px;
  justify-content: center;
  flex-wrap: wrap;
}

.footer-links a {
  color: rgba(255, 255, 255, 0.92);
  text-decoration: none;
  transition: color var(--transition);
}

.footer-links a:hover {
  color: var(--color-accent);
}

/* ==================================================================
   レスポンシブ：スマホ（768px以下）は縦並びに切り替え
   ================================================================== */
@media (max-width: 768px) {
  .header-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .hero {
    min-height: 60vh;
    padding: 60px 0;
  }

  /* モバイルは軽量な1280幅WebPを使用（非対応時はJPEGにフォールバック） */
  @supports (background-image: image-set(url("i.webp") type("image/webp"))) {
    .hero {
      background-image: var(--hero-overlay),
        image-set(
          url("/assets/images/hero-1280.webp") type("image/webp"),
          url("/assets/images/hero.jpg") type("image/jpeg")
        );
    }
  }

  .pain-nav {
    padding: 48px 0;
  }

  .pain-grid {
    grid-template-columns: 1fr; /* 3列 → 1列（縦並び） */
  }

  .content section {
    padding: 44px 0;
  }

  .btn-affiliate {
    display: flex;
    justify-content: center;
  }

  .btn-submit {
    align-self: stretch;
    text-align: center;
  }
}
