/* =============================================================
   spot.css — 観光スポットページ固有スタイル
   依存: css/common.css（デザイントークン定義済み）
   ============================================================= */

/* ============================================================
   ページ全体（ヘッダー固定分の余白）
   ============================================================ */
.spot-page {
  padding-top: 190.845px; /* ヘッダー固定高さ（PC） */
  min-height: 100vh;
  background-color: var(--color-bg-gray-03);
}

/* ============================================================
   パンくずリスト
   ============================================================ */
.spot-breadcrumb {
  padding: 8px 0;
  background-color: var(--color-bg-gray-03);
  border-bottom: 1px solid var(--color-border-gray-01);
}

.spot-breadcrumb__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding: 0 var(--container-medium);
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fontsize-text-small);
  font-family: var(--font-body);
  color: var(--color-font-black-01);
  line-height: 1.6;
}

.spot-breadcrumb__link {
  text-decoration: underline;
  color: var(--color-font-black-01);
  transition: opacity 0.2s ease;
}

.spot-breadcrumb__link:hover {
  opacity: 0.7;
}

.spot-breadcrumb__link:focus {
  outline: 2px solid var(--color-border-key);
  outline-offset: 2px;
  border-radius: 2px;
}

.spot-breadcrumb__sep {
  display: block;
  width: 4px;
  height: 5px;
  flex-shrink: 0;
}

.spot-breadcrumb__current {
  text-decoration: underline;
  color: var(--color-font-gray-01);
}

/* ============================================================
   ページ内コンテンツラッパー
   ============================================================ */
.spot-inner {
  padding-top: var(--margin-block-03); /* 80px */
  padding-bottom: var(--margin-block-04); /* 120px */
}

/* ============================================================
   ページタイトル
   ============================================================ */
.spot-page-ttl {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: var(--margin-block-03); /* 80px */
}

.spot-page-ttl__en {
  font-family: var(--font-accent);
  font-size: var(--fontsize-text-large); /* 20px */
  font-weight: 500;
  color: var(--color-font-keycolor);
  letter-spacing: 2px;
  line-height: normal;
  margin: 0;
}

.spot-page-ttl__ja {
  font-family: var(--font-heading);
  font-size: 48px;
  font-weight: 500;
  color: var(--color-font-black-01);
  letter-spacing: 2.4px;
  line-height: 1.4;
  margin: 0;
}

/* ============================================================
   絞込検索ボックス
   ============================================================ */
.spot-search {
  background-color: var(--color-bg-gray-04);
  border: 1px solid var(--color-border-gray-01);
  border-radius: var(--radius-nml);
  padding: var(--margin-block-02); /* 60px */
  display: flex;
  flex-direction: column;
  gap: var(--margin-block-01); /* 40px */
  margin-bottom: var(--margin-block-01); /* 40px */
}

/* 検索ボックスタイトル行 */
.spot-search__ttl-wrap {
  border-bottom: 1px solid var(--color-border-gray-01);
  padding-bottom: 15px;
  width: 100%;
}

.spot-search__ttl {
  font-family: var(--font-heading);
  font-size: 24px;
  font-weight: 500;
  color: var(--color-font-black-01);
  letter-spacing: 1.2px;
  line-height: normal;
  margin: 0;
}

/* 2列レイアウト（カテゴリー列 + エリア+キーワード列） */
.spot-search__selects {
  display: flex;
  gap: var(--margin-block-03); /* 80px */
  align-items: flex-start;
}

/* 右側コンテナ（エリア+キーワード縦積み） */
.spot-search__col--right {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--margin-block-01); /* 40px */
  align-items: flex-start;
}

/* エリア + 地図の横並びラッパー */
.spot-search__area-row {
  display: flex;
  align-items: flex-start;
  gap: var(--margin-block-01); /* 40px */
  width: 100%;
}

/* 各選択カラム（カテゴリー・エリア） */
.spot-search__col {
  display: flex;
  flex-direction: column;
  gap: var(--space-03); /* 30px */
  align-items: flex-start;
}

.spot-search__col--category {
  width: 360px;
  flex-shrink: 0;
}

/* カラムタイトル */
.spot-search__col-ttl-wrap {
  border-bottom: 1px dashed var(--color-border-black-01);
  width: 100%;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 10px;
}

.spot-search__col-ttl {
  font-family: var(--font-heading);
  font-size: var(--fontsize-text-large); /* 20px */
  font-weight: 500;
  color: var(--color-font-black-01);
  text-align: center;
  letter-spacing: 1px;
  line-height: 1.5;
  margin: 0;
}

/* ボタングループ */
.spot-search__col-btns {
  width: 360px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-02); /* 20px */
  align-items: flex-start;
}

/* ============================================================
   フィルターボタン共通
   ============================================================ */
.spot-filter-btn {
  cursor: pointer;
  font-family: var(--font-heading);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, opacity 0.2s ease;
}

.spot-filter-btn:focus {
  outline: 2px solid var(--color-border-key);
  outline-offset: 2px;
}

/* アクティブ（選択中: 全カテゴリー / 全地域） */
.spot-filter-btn--active {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 12px 30px 15px;
  background-color: var(--color-bg-keycolor-02);
  color: var(--color-font-white-01);
  border: none;
  border-radius: var(--radius-rounded);
  font-size: var(--fontsize-text-normal); /* 16px */
  font-weight: 500;
  line-height: 1.6;
}

.spot-filter-btn--active:hover {
  background-color: var(--color-bg-keycolor-dark-02);
}

.spot-filter-btn--active:active {
  background-color: var(--color-bg-keycolor-dark-02);
  opacity: 0.9;
}

/* カテゴリーボタングリッド */
.spot-filter-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}

/* カテゴリーボタン */
.spot-filter-btn--cat {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 175px;
  min-height: 62px;
  padding: 9px 20px 11px;
  background-color: var(--color-bg-gray-04);
  color: var(--color-font-gray-01);
  border: 1px solid var(--color-border-gray-03);
  border-radius: var(--radius-rounded);
  font-size: var(--fontsize-text-small); /* 14px */
  font-weight: 500;
  line-height: 1.5;
}

.spot-filter-btn--cat:hover {
  background-color: var(--color-bg-green-01);
  border-color: var(--color-border-key);
  color: var(--color-font-black-01);
}

.spot-filter-btn--cat:active {
  background-color: var(--color-bg-green-02);
  border-color: var(--color-border-key);
}

.spot-filter-btn--cat.is-active {
  background-color: var(--color-bg-keycolor-02);
  color: var(--color-font-white-01);
  border-color: var(--color-bg-keycolor-02);
}

/* エリアボタングリッド */
.spot-filter-areas {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}

/* エリアボタン */
.spot-filter-btn--area {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 175px;
  padding: 5px 30px 7px;
  background-color: var(--color-bg-gray-04);
  color: var(--color-font-gray-01);
  border: 1px solid var(--color-border-gray-03);
  border-radius: var(--radius-rounded);
  font-size: var(--fontsize-text-small); /* 14px */
  font-weight: 500;
  line-height: 1.6;
}

.spot-filter-btn--area:hover {
  background-color: var(--color-bg-green-01);
  border-color: var(--color-border-key);
  color: var(--color-font-black-01);
}

.spot-filter-btn--area:active {
  background-color: var(--color-bg-green-02);
  border-color: var(--color-border-key);
}

.spot-filter-btn--area.is-active {
  background-color: var(--color-bg-keycolor-02);
  color: var(--color-font-white-01);
  border-color: var(--color-bg-keycolor-02);
}

/* ============================================================
   地図
   ============================================================ */
.spot-search__map {
  flex-shrink: 0;
}

/* ============================================================
   キーワード検索
   ============================================================ */
.spot-search__keyword {
  display: flex;
  flex-direction: column;
  gap: var(--space-03); /* 30px */
  width: 100%;
}

.spot-keyword__input-wrap {
  position: relative;
  width: 100%;
}

.spot-keyword__input {
  width: 100%;
  height: 56px;
  padding: 16px 50px 16px 30px;
  background-color: var(--color-bg-gray-03);
  border: 1px solid var(--color-border-gray-03);
  border-radius: var(--radius-rounded);
  font-family: var(--font-heading);
  font-size: var(--fontsize-text-small); /* 14px */
  color: var(--color-font-black-01);
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
}

.spot-keyword__input::placeholder {
  color: var(--color-font-gray-02);
}

.spot-keyword__input:focus {
  border-color: var(--color-border-key);
  box-shadow: 0 0 0 2px var(--color-bg-green-02);
}

.spot-keyword__btn {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  color: var(--color-font-black-01);
  transition: opacity 0.2s ease;
}

.spot-keyword__btn:hover {
  opacity: 0.6;
}

.spot-keyword__btn:focus {
  outline: 2px solid var(--color-border-key);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ============================================================
   検索結果ヘッダー
   ============================================================ */
.spot-result-header {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  padding-bottom: 15px;
  border-bottom: 1px dashed var(--color-border-black-01);
  margin-bottom: var(--margin-block-01); /* 40px */
}

.spot-result-header__condition {
  font-family: var(--font-heading);
  font-size: var(--fontsize-text-normal); /* 16px */
  font-weight: 500;
  color: var(--color-font-black-01);
  letter-spacing: 0.8px;
  line-height: 1.5;
  margin: 0;
}

.spot-result-header__count {
  display: flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-heading);
  font-weight: 500;
  color: var(--color-font-black-01);
  line-height: 1.5;
  margin: 0;
}

.spot-result-header__count-label,
.spot-result-header__count-unit {
  font-size: var(--fontsize-text-normal); /* 16px */
  letter-spacing: 0.8px;
}

.spot-result-header__count-num {
  font-size: 24px;
  letter-spacing: 1.2px;
  font-weight: 700;
}

/* ============================================================
   スポットカード一覧（4列グリッド）
   ============================================================ */
.spot-list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: var(--margin-block-01); /* 40px */
}

/* ============================================================
   スポットカード
   ============================================================ */
.spot-card {
  display: flex;
  flex-direction: column;
  /* 4列: 25% - ボーダー考慮 */
  width: calc(25% - 1px);
  min-width: 200px;
  padding: 0 24px 40px;
  border-left: 1px dashed var(--color-border-black-01);
  text-decoration: none;
  color: inherit;
  transition: opacity 0.2s ease;
  box-sizing: border-box;
}

/* 5枚目以降は行間マージン */
.spot-card:nth-child(n+5) {
  margin-top: 40px;
}

/* 4列: 各行の右端カードに right border を追加 */
.spot-card:nth-child(4n) {
  border-right: 1px dashed var(--color-border-black-01);
}

.spot-card:hover {
  opacity: 0.8;
}

.spot-card:focus {
  outline: 2px solid var(--color-border-key);
  outline-offset: 2px;
}

/* 画像（横長: 288×213 比率） */
.spot-card__img {
  width: 100%;
  aspect-ratio: 288 / 213;
  overflow: hidden;
  background-color: var(--color-bg-green-01);
  flex-shrink: 0;
}

.spot-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-width: none; /* トラップ1対策: aspect-ratio親でもmax-width:100%が干渉するケース対策 */
}

/* テキストエリア */
.spot-card__txt {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-top: 20px;
  width: 100%;
}

/* タイトル */
.spot-card__title {
  font-family: var(--font-heading);
  font-size: var(--fontsize-text-medium); /* 18px */
  font-weight: 500;
  color: var(--color-font-black-01);
  line-height: 1.6;
  margin: 0;
}

/* 地域ラベル */
.spot-card__label {
  display: flex;
  align-items: center;
  gap: 5px;
}

.spot-card__region-icon {
  display: block;
  width: 12px;
  height: 16px;
  flex-shrink: 0;
  max-width: none; /* トラップ1対策 */
}

.spot-card__region {
  font-family: var(--font-heading);
  font-size: var(--fontsize-text-small); /* 14px */
  font-weight: 500;
  color: var(--color-font-gray-01);
  line-height: 1.6;
  white-space: nowrap;
}

/* ============================================================
   ページ下部ボタン
   ============================================================ */
.spot-footer-btn {
  display: flex;
  justify-content: center;
  padding-top: var(--margin-block-01); /* 40px */
}

/* ============================================================
   レスポンシブ: ミドル（max: 1200px）
   ============================================================ */
@media (max-width: 1200px) {
  .spot-page-ttl__ja {
    font-size: 36px;
  }

  .spot-search__selects {
    gap: var(--margin-block-01); /* 40px */
  }

  .spot-search__col--category,
  .spot-search__col-btns {
    width: 280px;
  }

  .spot-filter-btn--cat,
  .spot-filter-btn--area {
    width: 130px;
  }

  /* 3列 */
  .spot-card {
    width: calc(33.333% - 1px);
    min-width: 180px;
  }

  /* 4列用 right border をリセット */
  .spot-card:nth-child(4n) {
    border-right: none;
  }

  /* 3列: 各行の右端カードに right border */
  .spot-card:nth-child(3n) {
    border-right: 1px dashed var(--color-border-black-01);
  }

  /* 3列: 4枚目以降は行間マージン */
  .spot-card:nth-child(n+4) {
    margin-top: 40px;
  }
}

/* ============================================================
   レスポンシブ: モバイル（max: 767px）
   ============================================================ */
@media (max-width: 767px) {
  :root {
    --container-medium: 20px;
  }

  .spot-page {
    padding-top: 92px; /* モバイルヘッダー高さ */
  }

  .spot-inner {
    padding-top: var(--margin-block-02); /* 60px */
    padding-bottom: var(--margin-block-03); /* 80px */
  }

  .spot-page-ttl__en {
    font-size: var(--fontsize-text-normal); /* 16px */
  }

  .spot-page-ttl__ja {
    font-size: var(--fontsize-text-xxxlarge); /* 28px */
    letter-spacing: 1.4px;
  }

  .spot-search {
    padding: var(--margin-block-01) var(--space-02); /* 40px 20px */
    gap: var(--space-03); /* 30px */
  }

  /* モバイルでは1列 */
  .spot-search__selects {
    flex-direction: column;
    gap: var(--margin-block-01);
  }

  .spot-search__col--right {
    width: 100%;
  }

  .spot-search__area-row {
    flex-direction: column;
    gap: var(--margin-block-01);
    width: 100%;
  }

  .spot-search__col--category,
  .spot-search__col-btns {
    width: 100%;
  }

  /* カテゴリー / エリアボタン: 1行2列 */
  .spot-filter-btn--cat,
  .spot-filter-btn--area {
    width: calc(50% - 5px);
    min-width: 120px;
  }

  /* 地図: モバイルでは中央揃え */
  .spot-search__map {
    align-self: center;
  }

  /* カードリスト: 1列 */
  .spot-list {
    flex-direction: column;
    align-items: stretch;
  }

  .spot-card {
    width: 100%;
    min-width: unset;
    border-left: 1px dashed var(--color-border-black-01);
    border-right: none;
    padding: 0 var(--space-02) var(--space-02);
  }

  /* 全カードのnth-child指定をリセット */
  .spot-card:nth-child(n) {
    border-right: none;
    margin-top: var(--space-02);
  }

  .spot-card:first-child {
    margin-top: 0;
  }
}
