/* ==========================================================================
   宗蓮寺 カスタムCSS — Lightning子テーマ上書き
   Design System: sourenji-design-system.md 準拠
   ========================================================================== */

/* ------------------------------------------------------------------
   A) カラー・カスタムプロパティの上書き
   ------------------------------------------------------------------ */
:root {
  /* Lightning キーカラーの上書き */
  --vk-color-primary: #8B6914;
  --vk-color-primary-dark: #6B4F10;
  --vk-color-primary-vivid: #A07B1A;
  --wp--preset--color--vk-color-primary: #8B6914;
  --wp--preset--color--vk-color-primary-dark: #6B4F10;
  --wp--preset--color--vk-color-primary-vivid: #A07B1A;

  /* 宗蓮寺デザインシステム カスタムプロパティ */
  --color-text: #333333;
  --color-text-sub: #666666;
  --color-bg: #FFFFFF;
  --color-bg-section: #F5F3EF;
  --color-accent: #8B6914;
  --color-accent-green: #2E7D32;
  --color-header-bg: #1A1A1A;
  --color-header-text: #F0EDE6;
  --color-link-hover: #6B4F10;
  --color-border: #D4CFC5;

  /* フォント */
  --font-heading: "Noto Serif JP", "游明朝", "YuMincho", serif;
  --font-body: "Noto Sans JP", "游ゴシック", "YuGothic", sans-serif;

  /* スペーシング */
  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 24px;
  --space-lg: 40px;
  --space-xl: 64px;
  --space-2xl: 80px;
  --space-3xl: 120px;

  /* アニメーション */
  --transition-base: 0.3s ease;
  --transition-slow: 0.6s ease;
}

/* ------------------------------------------------------------------
   B) フォントの適用
   ------------------------------------------------------------------ */
body {
  font-family: var(--font-body);
  color: var(--color-text);
  line-height: 1.8;
}

h1, h2, h3, h4, h5, h6,
.site-header-logo,
.site-header-logo a {
  font-family: var(--font-heading);
}

/* ------------------------------------------------------------------
   C) ヘッダーのカスタマイズ
   ------------------------------------------------------------------ */
.site-header {
  background-color: var(--color-header-bg) !important;
  border-bottom: none !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
  position: fixed !important;
  top: 0;
  z-index: 1000;
}

/* スクロール後もデザインを変えない — 親テーマの全上書き */
.header_scrolled .site-header,
body.header_scrolled .site-header,
body.scrolled .site-header {
  background-color: var(--color-header-bg) !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
  position: fixed !important;
  top: 0 !important;
  animation: none !important;
  min-height: unset !important;
}

/* 親テーマがスクロール時にロゴ・サブヘッダーを非表示にするのを打ち消し */
.header_scrolled .site-header-logo,
body.header_scrolled .site-header-logo,
.header_scrolled .site-header-sub,
body.header_scrolled .site-header-sub,
.header_scrolled .header-top,
body.header_scrolled .header-top,
.header_scrolled .vk-campaign-text,
body.header_scrolled .vk-campaign-text {
  display: block !important;
}

/* スクロール時のロゴ・ナビ色も統一 */
.header_scrolled .site-header-logo a,
body.header_scrolled .site-header-logo a,
body.scrolled .site-header-logo a {
  color: var(--color-header-text) !important;
}

.header_scrolled .global-nav li a,
body.header_scrolled .global-nav li a,
body.scrolled .global-nav li a {
  color: var(--color-header-text) !important;
}

.header_scrolled .global-nav li a:hover,
body.header_scrolled .global-nav li a:hover,
body.scrolled .global-nav li a:hover {
  color: var(--color-accent) !important;
}

/* WP管理バーがある場合の補正 */
.admin-bar .site-header {
  top: 32px;
}

@media (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px;
  }
}

/* ロゴ */
.site-header-logo {
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.site-header-logo a,
.site-header-logo a:visited {
  color: var(--color-header-text);
  text-decoration: none;
}

.site-header-logo img + span,
.site-header-logo .site-header-logo__text {
  color: var(--color-header-text);
}

/* グローバルナビゲーション */
.global-nav li a {
  color: var(--color-header-text);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  font-weight: 500;
  position: relative;
  transition: color var(--transition-base);
  padding: 0.75em 1em;
}

/* ナビリンク下線アニメーション */
.global-nav li a::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background-color: var(--color-accent);
  transition: width var(--transition-base), left var(--transition-base);
}

.global-nav li a:hover,
.global-nav li a:focus {
  color: var(--color-accent);
  background-color: transparent;
}

.global-nav li a:hover::after,
.global-nav li a:focus::after {
  width: 100%;
  left: 0;
}

/* 現在ページのナビ表示 — 常に白で統一 */
.global-nav .current-menu-item > a,
.global-nav .current_page_item > a,
.global-nav .current-menu-ancestor > a {
  color: var(--color-header-text);
}

/* 現在ページでもホバー時はアクセント色に変わる */
.global-nav .current-menu-item > a:hover,
.global-nav .current_page_item > a:hover,
.global-nav .current-menu-ancestor > a:hover {
  color: var(--color-accent) !important;
}

/* ナビサブメニュー */
.global-nav .sub-menu {
  background-color: var(--color-header-bg);
  border: 1px solid rgba(240, 237, 230, 0.1);
}

.global-nav .sub-menu li a {
  color: var(--color-header-text);
  font-size: 0.875rem;
}

.global-nav .sub-menu li a:hover {
  color: var(--color-accent);
  background-color: rgba(139, 105, 20, 0.1);
}

/* ヘッダー内のユーティリティ要素の色 */
.site-header .site-header__utility,
.site-header .site-header__utility a {
  color: var(--color-header-text);
}

/* ------------------------------------------------------------------
   D) フッターのカスタマイズ
   ------------------------------------------------------------------ */
.site-footer {
  background-color: var(--color-header-bg);
  color: var(--color-header-text);
}

/* フッターナビゲーション */
.footer-nav {
  padding: 2em 0;
  border-bottom: 1px solid rgba(240, 237, 230, 0.15);
}

.footer-nav .footer-nav-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5em 2em;
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav .footer-nav-list li a {
  color: var(--color-header-text);
  font-family: var(--font-body);
  font-size: 0.9375rem;
  text-decoration: none;
  padding: 0.5em 0;
  transition: color var(--transition-base);
}

.footer-nav .footer-nav-list li a:hover {
  color: var(--color-accent);
}

.site-footer a {
  color: var(--color-header-text);
  transition: color var(--transition-base);
}

.site-footer a:hover {
  color: var(--color-accent);
}

.site-footer-copyright {
  font-size: 0.8125rem;
  color: rgba(240, 237, 230, 0.7);
  border-top: 1px solid rgba(240, 237, 230, 0.15);
  padding-top: 1.5em;
}

/* フッターウィジェット */
.site-footer .widget {
  color: var(--color-header-text);
}

.site-footer .widget-title {
  font-family: var(--font-heading);
  color: var(--color-header-text);
  border-bottom-color: var(--color-accent);
}

/* ------------------------------------------------------------------
   E) 全体のトーン調整
   ------------------------------------------------------------------ */

/* リンク色 */
a {
  color: var(--color-accent);
  transition: color var(--transition-base);
}

a:hover,
a:focus {
  color: var(--color-link-hover);
}

/* 記事内リンク */
.entry-body a,
.main-section a {
  color: var(--color-accent);
}

.entry-body a:hover,
.main-section a:hover {
  color: var(--color-link-hover);
}

/* セクション背景交互 */
.has-vk-color-custom-1-background-color {
  background-color: var(--color-bg-section) !important;
}

/* 見出しスタイル */
.entry-body h2,
.main-section h2 {
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.4;
  border-bottom: 2px solid var(--color-accent);
  padding-bottom: 0.4em;
  margin-bottom: 1.5em;
}

.entry-body h3,
.main-section h3 {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.375rem;
  line-height: 1.5;
  border-left: 4px solid var(--color-accent);
  padding-left: 0.75em;
  margin-bottom: 1em;
}

.entry-body h4,
.main-section h4 {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: 1.125rem;
  line-height: 1.5;
}

/* 区切り線 */
hr,
.wp-block-separator {
  border-color: var(--color-border);
}

/* ------------------------------------------------------------------
   F) ボタンスタイルの上書き
   ------------------------------------------------------------------ */
.btn-primary,
.btn.btn-primary,
.wp-block-button__link,
.wp-element-button,
.vk_button_link,
.btn.has-vk-color-primary-background-color {
  background-color: var(--color-accent) !important;
  border-color: var(--color-accent) !important;
  color: #FFFFFF !important;
  border-radius: 4px;
  padding: 12px 32px;
  font-family: var(--font-body);
  font-weight: 500;
  transition: background-color var(--transition-base), transform var(--transition-base);
}

.btn-primary:hover,
.btn.btn-primary:hover,
.wp-block-button__link:hover,
.wp-element-button:hover,
.vk_button_link:hover,
.btn.has-vk-color-primary-background-color:hover {
  background-color: var(--color-link-hover) !important;
  border-color: var(--color-link-hover) !important;
  color: #FFFFFF !important;
  transform: translateY(-1px);
}

/* アウトラインボタン */
.btn-outline-primary,
.is-style-outline .wp-block-button__link {
  background-color: transparent !important;
  border: 1px solid var(--color-accent) !important;
  color: var(--color-accent) !important;
  border-radius: 4px;
  padding: 12px 32px;
  transition: all var(--transition-base);
}

.btn-outline-primary:hover,
.is-style-outline .wp-block-button__link:hover {
  background-color: var(--color-accent) !important;
  color: #FFFFFF !important;
}

/* ------------------------------------------------------------------
   G) モバイルナビの調整
   旧：Lightning (#vk-mobile-nav) の見た目調整CSSがあったが、
       2026-04-25 にポートフォリオ仕様の独自ハンバーガー
       (.header__burger / .header__nav / .header__overlay) に置き換えたため削除。
       実装本体: functions.php の wp_footer 内（CSS/HTML/JS インライン）。
   ------------------------------------------------------------------ */

/* ------------------------------------------------------------------
   H) メインビジュアル（スライダー）周り
   ------------------------------------------------------------------ */

/* スライダーオーバーレイを軽くする */
.swiper-slide .mainVisual__inner::before,
.vk_slider_item-background-area::before,
.slide-background-cover::before {
  background: rgba(0, 0, 0, 0.2);
}

/* キャプションを明朝体に */
.swiper-slide .mainVisual__title,
.vk_slider_item .vk_slider_item_title,
.slide-text-title {
  font-family: var(--font-heading);
  font-weight: 700;
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
  letter-spacing: 0.1em;
}

.swiper-slide .mainVisual__caption,
.vk_slider_item .vk_slider_item_caption,
.slide-text-caption {
  font-family: var(--font-heading);
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.4);
}

/* ------------------------------------------------------------------
   I) カードコンポーネント
   ------------------------------------------------------------------ */
.vk_post .vk_post-body,
.card {
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.vk_post:hover .vk_post-body,
.card:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  transform: translateY(-4px);
}

.vk_post .vk_post_title {
  font-family: var(--font-heading);
}

/* ------------------------------------------------------------------
   J) お知らせリスト
   ------------------------------------------------------------------ */
.vk_post_list .vk_post .vk_post_date {
  color: var(--color-text-sub);
  font-size: 0.875rem;
}

.vk_post_list .vk_post .vk_post_title a {
  transition: color var(--transition-base);
}

.vk_post_list .vk_post .vk_post_title a:hover {
  color: var(--color-accent);
}

/* カテゴリバッジ */
.vk_post .vk_post_cat {
  background-color: var(--color-accent);
  color: #FFFFFF;
  border-radius: 12px;
  font-size: 0.75rem;
  padding: 2px 10px;
}

/* ------------------------------------------------------------------
   K) サイドバー
   ------------------------------------------------------------------ */
.sub-section .widget-title {
  font-family: var(--font-heading);
  border-left: 4px solid var(--color-accent);
  padding-left: 0.75em;
}

/* ------------------------------------------------------------------
   L) ページャー・パンくずリスト
   ------------------------------------------------------------------ */
.page-link a,
.nav-links a {
  color: var(--color-accent);
}

.page-link a:hover,
.nav-links a:hover {
  background-color: var(--color-accent);
  color: #FFFFFF;
}

.breadcrumb a {
  color: var(--color-accent);
}

/* ------------------------------------------------------------------
   M) フォーカス・アクセシビリティ
   ------------------------------------------------------------------ */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}

/* ------------------------------------------------------------------
   M-2) スムーススクロール & アンカーリンクのヘッダー隠れ対策
   ------------------------------------------------------------------ */
/* ヘッダー高さをカスタムプロパティ化（管理バー・ブレークポイントで再定義） */
:root {
  --header-height: 80px;
  --anchor-offset: 16px; /* 見出しの上に少し余白を足す */
}

/* スマホではヘッダー 60px */
@media (max-width: 767px) {
  :root {
    --header-height: 60px;
  }
}

/* 管理バー表示中の補正 */
.admin-bar {
  --header-height: 112px; /* 80 + 32 */
}
@media (max-width: 782px) {
  .admin-bar {
    --header-height: 106px; /* 60 + 46 */
  }
}

/* スムーススクロール */
html {
  scroll-behavior: smooth;
  /* ハッシュ遷移時のオフセット（Safari/Chrome/Firefox が対応） */
  scroll-padding-top: calc(var(--header-height) + var(--anchor-offset));
}

/* すべての id付き要素にスクロール余白を付与（既存デザインには影響しない） */
[id],
section[id],
.wp-block-group[id],
.wp-block-heading[id],
h1[id], h2[id], h3[id], h4[id], h5[id], h6[id],
a[id],
*[id^="section-"],
*[id="about"], *[id="kuyo"], *[id="kids"], *[id="news"], *[id="access"] {
  scroll-margin-top: calc(var(--header-height) + var(--anchor-offset));
}

/* ------------------------------------------------------------------
   N) レスポンシブ対応
   ------------------------------------------------------------------ */

/* タブレット */
@media (max-width: 1023px) {
  .site-header-logo {
    font-size: 1.3rem;
  }
}

/* スマートフォン */
@media (max-width: 767px) {
  body {
    font-size: 15px;
  }

  .site-header-logo {
    font-size: 1.2rem;
    letter-spacing: 0.05em;
  }

  .entry-body h2,
  .main-section h2 {
    font-size: 1.4rem;
  }

  .entry-body h3,
  .main-section h3 {
    font-size: 1.2rem;
  }

  /* ボタンのタップ領域確保 */
  .btn,
  .wp-block-button__link,
  .wp-element-button,
  .vk_button_link {
    min-height: 44px;
    padding: 12px 24px;
  }

  /* スライダーキャプション */
  .swiper-slide .mainVisual__title,
  .vk_slider_item .vk_slider_item_title {
    font-size: 1.5rem;
    letter-spacing: 0.05em;
  }
}

/* 小さいスマートフォン */
@media (max-width: 479px) {
  .site-header-logo {
    font-size: 1.1rem;
  }

  .entry-body h2,
  .main-section h2 {
    font-size: 1.25rem;
  }
}

/* ------------------------------------------------------------------
   O) ホーム限定：site-body の padding-top のみゼロに
   alignfull FV をヘッダーに直接接続させるため。
   padding-bottom はデフォルトを残し、各ページの最終セクションは
   白背景で統一して、自然にフッターに繋がるようにする。
   ------------------------------------------------------------------ */
.home .site-body,
.page-id-9 .site-body {
  padding-top: 0 !important;
}

/* =================================================================
 * Home section card-thumb (uniform aspect ratio)
 * 2026-04-22
 * ================================================================= */
.wp-block-image.card-thumb {
  margin: 0 0 1rem 0;
}
.wp-block-image.card-thumb img {
  width: 100%;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

/* =================================================================
 * 全固定ページ：コンテンツセクション（alignfull系）の上下余白を
 * 100px に統一
 * 2026-04-24
 *
 * 対象:
 *   - .page / .home の wp-block-group.alignfull
 *   - .full-width-beige / .full-width-gray（HTMLブロックのカスタム要素）
 * 例外:
 *   - wp-block-cover.alignfull（FV）。既にviewportいっぱいの
 *     ビジュアル要素なので padding はゼロを維持。
 *
 * 併せて固定ページ post_content 内のセクション末尾にある
 * 「height:100px のwp:spacer」は削除する運用（重複回避）。
 * ================================================================= */
.page .wp-block-group.alignfull,
.home .wp-block-group.alignfull,
.full-width-beige,
.full-width-gray {
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}

/* FV（wp-block-cover）は上下padding 0 固定（対象外） */
.wp-block-cover.alignfull {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* =================================================================
 * 随時見学・入団可バッジ / カード見出し内インラインバッジ
 * 2026-04-25（和尚さん依頼 #13, #17）
 * ================================================================= */

/* 対象欄の「随時見学・入団可」バッジ（子供会ページ） */
.club-open-badge {
  display: inline-block;
  padding: 4px 14px;
  background: #d9534f;
  color: #fff;
  border-radius: 999px;
  font-size: 0.875rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.4;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}

/* 空手「中学生以上可」「中学生可」バッジ（既存.club-badge-redが未定義なら念のため定義） */
.club-badge-red {
  display: inline-block;
  margin-left: 0.5em;
  padding: 2px 10px;
  background: #d9534f;
  color: #fff;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  vertical-align: middle;
}

/* ホームカード見出し横のインラインバッジ「随時見学・入団可」 */
.card-badge-inline {
  display: inline-block;
  margin-left: 0.6em;
  padding: 3px 12px;
  background: #d9534f;
  color: #fff;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  vertical-align: middle;
  box-shadow: 0 1px 2px rgba(0,0,0,0.08);
}
@media (max-width: 600px) {
  .card-badge-inline {
    display: inline-block;
    margin-left: 0;
    margin-top: 4px;
    font-size: 0.72rem;
  }
}

/* ==================================================================
   ハンバーガーボタン オーバーフロー修正（モバイル）
   2026-04-22 追加
   ------------------------------------------------------------------
   問題: モバイル時にヘッダー高さ 35.56px に対して
         ボタン top:18px / height:28px → 底 46px
         → 10.44px ヘッダー外にはみ出して FV 上に貼り付き
   解決: ヘッダー最小高さを 60px に確保し、
         ボタンを top:16px に下げて、ヘッダー内 (60px) の縦中央
         (60-28)/2 = 16px に配置する。
   注意: .header__burger は position: fixed なので、top:50% は
         viewport 全高の 50% になってしまい NG（画面中央に飛ぶ）。
         そのため固定値 16px を使用する。
         is-open 時の span translateY アニメは
         親 .header__burger の transform とは独立なので競合なし。
   ================================================================== */
@media (max-width: 1023px) {
  /* 1) ヘッダーの最小高さを 60px 確保（モバイル） */
  .site-header,
  #site-header,
  .site-header__inner,
  .site-header > .container,
  .site-header > .container > .row {
    min-height: 60px !important;
  }

  /* 2) ハンバーガーボタンを 60px ヘッダー内の縦中央へ
        body 接頭辞で特異性を上げ、functions.php インライン CSS の
        .header__burger { top: 18px } (特異性 0,1,0) を確実に上書き
        (特異性 0,1,1) */
  body .header__burger,
  html body .header__burger {
    top: 16px !important; /* (60 - 28) / 2 = 16px */
  }

  /* 3) admin-bar (モバイル: 46px) 表示時 */
  body.admin-bar .header__burger,
  html body.admin-bar .header__burger {
    top: calc(16px + 46px) !important; /* 62px */
  }
}

/* デスクトップ admin-bar (32px) 範囲のみ */
@media (max-width: 1023px) and (min-width: 783px) {
  body.admin-bar .header__burger,
  html body.admin-bar .header__burger {
    top: calc(16px + 32px) !important; /* 48px */
  }
}

/* ==================================================================
   モバイルヘッダー：ロゴ中央配置 & ×アイコン視認性修正
   2026-04-25
   ------------------------------------------------------------------
   問題①: モバイル時ヘッダーの「宗蓮寺」テキストが左寄りで配置イマイチ
          → 横も縦も中央に配置したい（右上のハンバーガーは fixed
            なので衝突しない）
   問題②: メニュー展開時(is-open)、白い nav パネルの×アイコンが
          薄ベージュ #F0EDE6 のままで白背景に同化して見えない
          → is-open 時のみ #333333 の濃い色に切り替え。
            色変更も transition で滑らかに連動
   ================================================================== */

/* ① モバイルヘッダーロゴを横縦中央へ
   実DOM構造:
     header.site-header (flex親, min-height:60px)
       └ div.site-header-container.container (中間ラッパー)
            └ h1.site-header-logo (テキスト)
   → site-header と中間ラッパーの両方を flex 中央化する。
     中間ラッパーが ヘッダー60px を block で占有していると、
     その中で h1 は文書フロー上端に貼り付くため縦中央にならない。 */
@media (max-width: 1023px) {
  .site-header,
  #site-header,
  .site-header__inner,
  .site-header-container,
  .site-header > .site-header-container {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 60px !important;
  }

  .site-header-logo {
    text-align: center !important;
    margin: 0 auto !important;
  }
  /* ハンバーガーは position: fixed（functions.php 側）なので
     flex 中央レイアウトに巻き込まれず右上に出続ける */
}

/* ② is-open 時の×アイコン線色を濃い色に上書き
   functions.php インライン CSS の
   `.header__burger span { background-color: #F0EDE6 !important }` を
   特異性 + !important で確実に上書きする */
body .header__burger.is-open span,
html body .header__burger.is-open span {
  background-color: #333333 !important;
  /* 既存 transition (transform/opacity) に background-color を追加し
     X字変形と色変更が同時に滑らかに切り替わるようにする */
  transition: transform 0.3s ease, opacity 0.3s ease, background-color 0.3s ease !important;
}

/* ==================================================================
   ホームFV: PC時は高さ固定700px、幅100vw全幅（シンプル方式）
   2026-04-25 修正
   ------------------------------------------------------------------
   経緯: aspect-ratio + max-height + margin auto の組み合わせは
         alignfullの負値マージンと衝突して大画面でFVが親要素幅
         (1110px)に閉じ込められる問題が発生。
   方針: 高さは700pxで固定、幅は alignfull の負値マージンで100vw 全幅維持。
         object-fit: cover で画像中央トリミング表示。
   スマホ・タブレット (<1024px): WP コアの min-height: 430px を維持
   ================================================================== */
@media (min-width: 1024px) {
  .home .wp-block-cover.alignfull,
  .home .wp-block-cover.alignfull.is-light {
    height: 700px !important;
    min-height: 700px !important;
    max-height: 700px !important;
    aspect-ratio: auto !important;  /* 既存の 16/7 を打ち消し */
    /* margin-left/right は alignfull のデフォルト calc(50% - 50vw) を維持 */
  }
}

/* ==================================================================
   .site-header::after（Lightning親テーマの clearfix）を完全削除
   2026-04-22
   ------------------------------------------------------------------
   経緯: 親テーマが
           .site-header::after { content: ""; clear: both; display: block; }
         を出力。height:0 で視覚的影響はないが、ねりさんから「after を
         消すよう指示したのに残ってる」と指摘あり。
   解決: 子テーマで display:none と content:none を !important で
         上書きし、疑似要素そのものをレンダリングしない状態にする。
   影響: ヘッダー内に float 要素は配置していないため clearfix を
         無効化してもレイアウト崩れは発生しない。
         （.site-header は flex / position:fixed 構成）
   ================================================================== */
.site-header::after {
  display: none !important;
  content: none !important;
}

/* ============================================
   祈願・供養3カードの高さ揃え（PC）
   2026-04-26 追加
   背景: ご祈祷だけ本文1行短く凹む問題への対応
============================================ */
@media (min-width: 768px) {
  .wp-block-columns.is-layout-flex
    > .wp-block-column
    > .wp-block-group.is-style-vk-group-solid-roundcorner {
    height: 100%;
    display: flex;
    flex-direction: column;
  }
}

/* ============================================
   子供会ページ 種目4カードのレスポンシブ調整
   2026-04-27 改訂
   背景: 「場所：加茂小学校体育館」(13文字×14px≈182px) を1行表示するため
         カード本文幅190px以上 → カード幅240px以上 → コンテナ1100px以上が必要。
         992px起点では約222pxとなり改行発生したため、1100pxに引き上げ。
         同時にcustom_css側で .club-grid に max-width 1400px、
         .club-card に max-width 320px を設定し、広い画面で拡大、
         過大化を防ぐ仕組みに変更。
   - <768px       : 1列縦並び
   - 768〜1099px  : 2x2グリッド（Lightning PCナビ切替992pxとは別軸）
   - 1100px〜     : 4列横並び（カード幅約241〜320pxの範囲で可変）
============================================ */
@media (min-width: 768px) and (max-width: 1099px) {
  .club-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (min-width: 1100px) {
  .club-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  .club-card h3 {
    font-size: 1.1rem !important;
  }
}

/* スクロールターゲット（ヘッダー固定分のオフセット）
   ヘッダー高さは Lightning デフォルト ≈ 80px、admin-bar 表示時は更に +32/46px */
#clubs {
  scroll-margin-top: 90px;
}
html {
  scroll-behavior: smooth;
}

/* 「上記の各種目欄」アンカーリンク（インライン表示）
   宗蓮寺デザインシステムのアクセント色（金茶 #8B6914）に準拠 */
.club-inline-link {
  color: #8B6914;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s ease;
}
.club-inline-link:hover,
.club-inline-link:focus {
  color: #6B4F10;
  text-decoration: underline;
}

/* ============================================
   子供会ページ FV直下H2の意図的改行制御
   2026-04-26 追加 / 2026-04-27 境界値570→640に変更
   - 640px以上：<br class="break-narrow"> を非表示で1行表示
   - 639px以下：<br class="break-narrow"> を有効化し「、」直後で2行
   - 背景：570px時に自然折り返しが発生するため境界を上げて中途半端な改行を排除
============================================ */
.break-narrow {
  display: none;
}
@media (max-width: 639px) {
  .break-narrow {
    display: inline;
  }
}

/* ============================================
   子供会ページ container 拡大（種目4カード用）
   2026-04-27 差し戻し修正
   ------------------------------------------------------------------
   背景: .club-grid に max-width 1400px / .club-card に max-width 320px
         を指定したが、親要素 .site-body-container.container が
         Bootstrap-3 由来の max-width: 1140px で頭打ちになっており、
         1280/1440/1600/1920px viewport でカード幅が 243.5px 止まり、
         1100px viewport では 198.5px まで縮んで「バスケットボール」
         「加茂小学校体育館」が改行する事故が起きていた。
   解決: 子供会ページ (page-id-13) に限定して .site-body-container を
         max-width: 1400px に拡大し、内側の .club-grid 1400px 制約を
         有効化する。
   影響: ヘッダー (#site-header-container) は別ラッパーのため影響なし。
         FV (.club-hero) はセクション全幅・中身は独自max-widthのため影響なし。
         本文セクション (H2/参加見学/FAQ) は中央寄せで余裕があるため
         多少広がっても可読性に影響なし。
   ================================================================== */
.page-id-13 .site-body-container {
  max-width: 1400px !important;
}

/* ============================================
   子供会ページ 種目4カード 768〜1099px のグリッド固定幅
   2026-04-26 追加
   ------------------------------------------------------------------
   背景: .site-body-container を 1400px に拡大した結果、
         768〜1099px の 2x2 レイアウトでは画面幅が広がっても
         .club-card の max-width:320px が効いて中央寄せされ、
         左右余白だけが拡大して間延び感が発生していた
         （特に 991px 付近で左右余白約170px）。
   解決: 768〜1099px では .club-grid 自体を max-width:900px に
         固定し、コンパクトに表示する。.club-card の 320px 制約は維持。
   - <768px       : 1列縦並び（既存・触らない）
   - 768〜1099px  : 2x2グリッド + .club-grid max-width:900px 固定（今回追加）
   - 1100px〜     : 4列横並び（既存・触らない）
============================================ */
@media (min-width: 768px) and (max-width: 1099px) {
  .club-grid {
    max-width: 900px !important;
  }
}
