/**
 * About ページ専用 CSS
 * slug: about
 * body class: .page-id-XXX または .page-template-page-about
 *
 * ルール追加時は必ずページスコープを付けること。
 * 例: body.page-template-page-about .ms-about { ... }
 *     body[class*="page-id-"] .ms-about { ... }
 *
 * style_part_01.css: .ms-about ベーススタイルを移行
 * style_part_02.css: レイアウト統一（l-container）を移行
 * style_part_03.css: 活動内容アイテム背景・レイアウトを移行
 * style_part_04.css: 768px レスポンシブを移行
 * style_part_05.css: 移行対象なし
 * style_part_06.css: 活動内容1列化・モバイル対策を移行
 * style_part_07.css: 移行対象なし
 */

/* ===== About ページ ベーススタイル ===== */
body.page-template-page-about .ms-about,
body[class*="page-id-"] .ms-about {
  line-height: 1.85;
  color: var(--ms-text);
}

/* ===== About（/about/）のレイアウト統一 ===== */
body.page-template-page-about .ms-about.l-container,
body[class*="page-id-"] .ms-about.l-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 16px;
}

/* PC */
@media (min-width: 1025px) {
  body.page-template-page-about .ms-about.l-container > *,
  body[class*="page-id-"] .ms-about.l-container > * {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* タブレット */
@media (min-width: 769px) and (max-width: 1024px) {
  body.page-template-page-about .ms-about.l-container > *,
  body[class*="page-id-"] .ms-about.l-container > * {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* スマホ */
@media (max-width: 768px) {
  body.page-template-page-about .ms-about.l-container > *,
  body[class*="page-id-"] .ms-about.l-container > * {
    width: 100%;
  }
}

/* ===== 「こんな雰囲気で活動してます！」枠の大きさ調整（Aboutページのみ） ===== */
body.page-template-page-about .ms-about .ms-atmosphere,
body[class*="page-id-"] .ms-about .ms-atmosphere {
  padding: 24px !important;
  margin-top: 24px !important;
  margin-bottom: 24px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  border-radius: 14px;
}
body.page-template-page-about .ms-about .ms-atmosphere-grid,
body[class*="page-id-"] .ms-about .ms-atmosphere-grid {
  gap: 18px;
  margin-top: 16px;
}
body.page-template-page-about .ms-about .ms-atmosphere-item,
body[class*="page-id-"] .ms-about .ms-atmosphere-item {
  padding: 18px !important;
  border-radius: 12px;
}
body.page-template-page-about .ms-about .ms-atmosphere-icon,
body[class*="page-id-"] .ms-about .ms-atmosphere-icon {
  margin-bottom: 12px;
}
body.page-template-page-about .ms-about .ms-atmosphere-item h3,
body[class*="page-id-"] .ms-about .ms-atmosphere-item h3 {
  margin: 0 0 8px 0;
  font-size: 17px;
}
body.page-template-page-about .ms-about .ms-atmosphere-item p,
body[class*="page-id-"] .ms-about .ms-atmosphere-item p {
  font-size: 0.95rem;
  line-height: 1.55;
}

@media (max-width: 768px) {
  body.page-template-page-about .ms-about .ms-atmosphere,
  body[class*="page-id-"] .ms-about .ms-atmosphere {
    padding: 16px !important;
    margin-top: 18px !important;
    margin-bottom: 18px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  body.page-template-page-about .ms-about .ms-atmosphere-grid,
  body[class*="page-id-"] .ms-about .ms-atmosphere-grid {
    gap: 14px;
    margin-top: 12px;
  }
  body.page-template-page-about .ms-about .ms-atmosphere-item,
  body[class*="page-id-"] .ms-about .ms-atmosphere-item {
    padding: 16px !important;
  }
  body.page-template-page-about .ms-about .ms-atmosphere-item h3,
  body[class*="page-id-"] .ms-about .ms-atmosphere-item h3 {
    font-size: 16px;
  }
}

/* ===== aboutページの活動内容アイテムの背景色を白に変更 ===== */
body.page-template-page-about .ms-about .ms-activity-item,
body[class*="page-id-"] .ms-about .ms-activity-item {
  background: #fff;
}

/* ===== Aboutページ用の活動内容レイアウト ===== */
body.page-template-page-about .ms-about .ms-activity-content,
body[class*="page-id-"] .ms-about .ms-activity-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  align-items: start;
  margin-top: 20px;
}

/* Aboutページの活動内容レスポンシブ対応（900px以下で1列化） */
@media (max-width: 900px) {
  body.page-template-page-about .ms-about .ms-activity-content,
  body[class*="page-id-"] .ms-about .ms-activity-content {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* Aboutページの活動内容レスポンシブ対応（768px以下） */
@media (max-width: 768px) {
  body.page-template-page-about .ms-about .ms-activity-content,
  body[class*="page-id-"] .ms-about .ms-activity-content {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}

/* ====== About/活動内容を常に1列に（練習→交流→写真の縦並び） ====== */
body.page-template-page-about .ms-about .ms-activity-content,
body[class*="page-id-"] .ms-about .ms-activity-content {
  display: grid;
  grid-template-columns: 1fr !important;
  gap: 20px !important;
}

/* 並び順を明示（左カラム相当の内容を先に、写真を後に） */
body.page-template-page-about .ms-about .ms-activity-schedule,
body[class*="page-id-"] .ms-about .ms-activity-schedule {
  order: 1 !important;
}
body.page-template-page-about .ms-about .ms-activity-image,
body[class*="page-id-"] .ms-about .ms-activity-image {
  order: 2 !important;
}

/* About の活動内容をスマホで安全に収める */
@media (max-width: 768px) {
  body.page-template-page-about .ms-about .ms-activity-content,
  body[class*="page-id-"] .ms-about .ms-activity-content {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
  }
  body.page-template-page-about .ms-about .ms-activity,
  body[class*="page-id-"] .ms-about .ms-activity {
    padding: 18px 14px !important;
    overflow: hidden !important;
    max-width: 100% !important;
  }
  body.page-template-page-about .ms-about .ms-activity-item,
  body.page-template-page-about .ms-about .ms-activity-image,
  body.page-template-page-about .ms-about .ms-activity-image .ms-media__img,
  body[class*="page-id-"] .ms-about .ms-activity-item,
  body[class*="page-id-"] .ms-about .ms-activity-image,
  body[class*="page-id-"] .ms-about .ms-activity-image .ms-media__img {
    margin: 0 !important;
    max-width: 100% !important;
  }
  body.page-template-page-about .ms-about .ms-activity-image img,
  body[class*="page-id-"] .ms-about .ms-activity-image img {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
  }
}

/* ===== /about/ 主な活動内容 専用ブロック ===== */
body.page-template-page-about .ms-about.l-container > .ms-about-activities,
body[class*="page-id-"] .ms-about.l-container > .ms-about-activities {
  width: 100% !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
  box-sizing: border-box !important;
  max-width: 100% !important;
  overflow-x: hidden !important;
}

body.page-template-page-about .ms-about-activities,
body.page-template-page-about .ms-about-activities *,
body[class*="page-id-"] .ms-about-activities,
body[class*="page-id-"] .ms-about-activities * {
  box-sizing: border-box !important;
}

body.page-template-page-about .ms-about-activities .ms-activity-content,
body[class*="page-id-"] .ms-about-activities .ms-activity-content {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
}

body.page-template-page-about .ms-about-activities .ms-activity-item,
body.page-template-page-about .ms-about-activities .ms-activity-image,
body.page-template-page-about .ms-about-activities .ms-activity-image .ms-media__img,
body[class*="page-id-"] .ms-about-activities .ms-activity-item,
body[class*="page-id-"] .ms-about-activities .ms-activity-image,
body[class*="page-id-"] .ms-about-activities .ms-activity-image .ms-media__img {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
}

body.page-template-page-about .ms-about-activities img,
body[class*="page-id-"] .ms-about-activities img {
  display: block !important;
  max-width: 100% !important;
  height: auto !important;
}

/* /about の活動内容：スマホは常に1列に */
@media (max-width: 900px) {
  body.page-template-page-about .ms-about .ms-activity-content,
  body[class*="page-id-"] .ms-about .ms-activity-content {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin: 0 !important;
    padding: 0 !important;
    max-width: 100% !important;
  }
  body.page-template-page-about .ms-about .ms-activity-item,
  body.page-template-page-about .ms-about .ms-activity-image,
  body.page-template-page-about .ms-about .ms-activity-image .ms-media__img,
  body[class*="page-id-"] .ms-about .ms-activity-item,
  body[class*="page-id-"] .ms-about .ms-activity-image,
  body[class*="page-id-"] .ms-about .ms-activity-image .ms-media__img {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }
  body.page-template-page-about .ms-about .ms-activity-image img,
  body[class*="page-id-"] .ms-about .ms-activity-image img {
    display: block !important;
    max-width: 100% !important;
    height: auto !important;
  }
  body.page-template-page-about .ms-about .ms-activity,
  body[class*="page-id-"] .ms-about .ms-activity {
    padding: 16px !important;
    overflow: hidden !important;
  }
}

/* Aboutページ専用の強力なモバイル対策 */
@media (max-width: 768px) {
  body.page-template-page-about .ms-about,
  body[class*="page-id-"] .ms-about {
    overflow-x: hidden !important;
    max-width: 100% !important;
  }
  body.page-template-page-about .ms-about.l-container,
  body[class*="page-id-"] .ms-about.l-container {
    padding-left: 8px !important;
    padding-right: 8px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  body.page-template-page-about .ms-about .ms-block,
  body.page-template-page-about .ms-about .ms-atmosphere,
  body.page-template-page-about .ms-about .ms-activity,
  body.page-template-page-about .ms-about .ms-participation,
  body[class*="page-id-"] .ms-about .ms-block,
  body[class*="page-id-"] .ms-about .ms-atmosphere,
  body[class*="page-id-"] .ms-about .ms-activity,
  body[class*="page-id-"] .ms-about .ms-participation {
    max-width: 100% !important;
    overflow-x: hidden !important;
    box-sizing: border-box !important;
  }
  body.page-template-page-about .ms-about .ms-activity,
  body[class*="page-id-"] .ms-about .ms-activity {
    padding: 12px !important;
    margin: 15px 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
  body.page-template-page-about .ms-about .ms-activity-content,
  body[class*="page-id-"] .ms-about .ms-activity-content {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
  body.page-template-page-about .ms-about img,
  body[class*="page-id-"] .ms-about img {
    max-width: 100% !important;
    height: auto !important;
    box-sizing: border-box !important;
  }
  body.page-template-page-about .ms-about .ms-atmosphere-grid,
  body.page-template-page-about .ms-about .ms-participation-grid,
  body.page-template-page-about .ms-about .ms-member-cards,
  body.page-template-page-about .ms-about .activity-grid,
  body[class*="page-id-"] .ms-about .ms-atmosphere-grid,
  body[class*="page-id-"] .ms-about .ms-participation-grid,
  body[class*="page-id-"] .ms-about .ms-member-cards,
  body[class*="page-id-"] .ms-about .activity-grid {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }
}
