/* =============================================================
   event.css — イベントを探すページ固有スタイル
   依存: css/common.css（デザイントークン定義済み）
   ============================================================= */

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

/* ============================================================
   パンくずリスト
   ============================================================ */
.event-breadcrumb {
  padding: 8px var(--container-medium);
}

.event-breadcrumb__inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: var(--fontsize-text-small);
  font-family: var(--font-body);
  color: var(--color-font-black-01);
  line-height: 1.6;
}

.event-breadcrumb__link {
  text-decoration: underline;
  color: var(--color-font-black-01);
  letter-spacing: 0.28px;
  transition: opacity 0.2s ease;
}

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

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

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

.event-breadcrumb__current {
  color: var(--color-font-black-01);
  letter-spacing: 0.28px;
}

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

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

.event-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;
}

.event-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;
}

/* ============================================================
   絞込検索ボックス
   ============================================================ */
.event-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) var(--margin-block-02); /* 60px */
  display: flex;
  flex-direction: column;
  gap: var(--margin-block-01); /* 40px */
  margin-bottom: var(--margin-block-01); /* 40px */
}

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

.event-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列レイアウト（月列 + エリア+地図列） */
.event-search__selects {
  display: flex;
  gap: var(--margin-block-02); /* 60px */
  align-items: flex-start;
}

/* エリア選択 + 地図の横並びラッパー */
/* 右カラム全体: タイトル上 + ボタン+地図の横並び下 */
.event-search__col--area-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--space-03); /* 30px: タイトルとコンテンツ間 */
  flex: 1;
  min-width: 0;
}

/* ボタン + 地図の横並び行 */
.event-search__area-content {
  display: flex;
  align-items: flex-start;
  gap: var(--margin-block-01); /* 40px */
  width: 100%;
}

/* 各選択カラム（月のみ残す） */
.event-search__col {
  display: flex;
  flex-direction: column;
  gap: var(--space-03); /* 30px */
  align-items: flex-start;
}

.event-search__col--month {
  width: 360px;
  flex-shrink: 0;
}

/* カラムタイトル */
.event-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;
}

.event-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;
}

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

/* ============================================================
   フィルターボタン共通
   ============================================================ */
.event-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;
}

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

/* アクティブ（選択中: オールシーズン / 全地域） */
.event-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;
}

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

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

/* 月ボタングリッド */
.event-filter-months {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
}

/* 月ボタン（非アクティブ） */
.event-filter-btn--month {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 108px;
  padding: 4px 10px 6px;
  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;
}

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

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

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

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

/* エリアボタン（非アクティブ） */
.event-filter-btn--area {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 168px;
  padding: 5px 20px 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;
}

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

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

.event-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);
}

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

/* ============================================================
   検索結果ヘッダー
   ============================================================ */
.event-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 */
}

.event-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;
}

.event-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;
}

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

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

/* ============================================================
   イベントカード一覧
   ============================================================ */
.event-list {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  margin-bottom: var(--margin-block-01); /* 40px */
  /* 4列: (320px * 4) + ボーダーがカード内包のため調整 */
}

/* ============================================================
   イベントカード
   ============================================================ */
.event-card {
  display: flex;
  flex-direction: column;
  gap: 20px;
  /* 4列: 25% - ボーダー考慮 */
  width: calc(25% - 1px);
  min-width: 240px;
  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枚目以降は行間マージン */
.event-card:nth-child(n+5) {
  margin-top: 40px;
}

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

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

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

/* サムネイル */
.event-card__thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
  background-color: var(--color-bg-green-01);
  flex-shrink: 0;
}

.event-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  max-width: 100%; /* トラップ1: aspect-ratio親での挙動は問題ない */
}

/* テキストエリア */
.event-card__txt {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  width: 100%;
}

/* 日付・カテゴリ行 */
.event-card__head {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: var(--fontsize-text-small); /* 14px */
  line-height: 1.5;
  white-space: nowrap;
}

.event-card__date {
  font-family: var(--font-date);
  font-weight: 400;
  color: var(--color-font-gray-02);
}

.event-card__cat {
  font-family: var(--font-heading);
  font-weight: 700;
  color: var(--color-bg-keycolor-02);
  font-size: var(--fontsize-text-small);
}

/* タイトル */
.event-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.8;
  margin: 0;
}

/* 詳細情報（日時・場所） */
.event-card__details {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--font-body);
  font-weight: 400;
  font-size: var(--fontsize-text-small); /* 14px */
  color: var(--color-font-black-01);
}

.event-card__details p {
  line-height: 1.8;
  margin: 0;
}

.event-card__place {
  display: flex;
  align-items: flex-start;
  line-height: 1.7;
}

.event-card__place span:first-child {
  white-space: nowrap;
  flex-shrink: 0;
}

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

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

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

  .event-search__col--month,
  .event-search__col--area {
    width: 280px;
  }

  .event-filter-btn--month {
    width: 84px;
  }

  .event-filter-btn--area {
    width: 130px;
  }

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

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

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

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

/* ============================================================
   レスポンシブ: モバイル（max: 767px）
   ============================================================ */
@media (max-width: 767px) {
  /* ルート変数のモバイル上書き（container-mediumはcommon.cssで定義済み想定） */
  :root {
    --container-medium: 20px;
  }

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

  .event-breadcrumb {
    padding: 12px var(--space-01);
  }

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

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

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

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

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

  .event-search__col--area-wrap {
    width: 100%;
  }

  .event-search__area-content {
    flex-direction: column;
    gap: var(--space-03); /* 30px */
  }

  .event-search__col--month,
  .event-search__col-btns {
    width: 100%;
  }

  /* 月ボタン: 1行3列 */
  .event-filter-btn--month {
    width: calc(33.333% - 8px);
    min-width: 70px;
  }

  /* エリアボタン: 1行2列 */
  .event-filter-btn--area {
    width: calc(50% - 5px);
    min-width: 120px;
  }

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

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

  .event-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指定をリセット */
  .event-card:nth-child(n) {
    border-right: none;
    margin-top: var(--space-02);
  }

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