/**
 * Components
 *
 * 共通コンポーネント (ボタン、カード、ヘッダー、フッター、スキップリンク等) の骨組み。
 * Phase 1 では最低限の見た目のみ。Phase 4-5 でモックに合わせ精緻化する。
 *
 * @package JobJepang
 */

/* ============================================================
   SKIP LINK (a11y)
   v1.4 §9.4
   ============================================================ */

.jj-skip-link {
  position: absolute;
  left: -9999px;
  top: -9999px;
  z-index: var(--jj-z-skiplink);
}

.jj-skip-link:focus,
.jj-skip-link:focus-visible {
  position: fixed;
  top: var(--jj-space-4);
  left: var(--jj-space-4);
  padding: var(--jj-space-3) var(--jj-space-6);
  background: var(--jj-primary);
  color: var(--jj-text-on-primary);
  text-decoration: none;
  border-radius: var(--jj-radius-md);
  box-shadow: var(--jj-shadow-md);
  font-weight: var(--jj-font-semibold);
}

/* ============================================================
   BUTTON (Phase 4-5 で精緻化、Phase 1 は枠だけ)
   ============================================================ */

.jj-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--jj-space-3) var(--jj-space-6);
  border-radius: var(--jj-radius-md);
  font-weight: var(--jj-font-semibold);
  font-size: var(--jj-text-md);
  line-height: var(--jj-leading-normal);
  text-decoration: none;
  transition: background-color var(--jj-transition-fast),
              box-shadow var(--jj-transition-fast),
              transform var(--jj-transition-fast);
  cursor: pointer;
}

/* v1.2.5: 控えめなリフトアップ。-1px のみ、派手なアニメーションは禁止。
   primary / secondary 共通の hover 動作として 1 箇所で定義する。 */
.jj-btn-primary:hover,
.jj-btn-secondary:hover {
  transform: translateY(-1px);
}

.jj-btn-primary {
  /* v1.2.6: 白文字とのコントラストを WCAG AA に。--jj-accent (#FF6B35) は装飾用として温存。 */
  background: var(--jj-cta-bg);
  color: var(--jj-text-on-primary);
}

.jj-btn-primary:hover {
  background: var(--jj-cta-bg-hover);
  color: var(--jj-text-on-primary);
  box-shadow: var(--jj-shadow-md);
}

.jj-btn-secondary {
  background: var(--jj-bg-white);
  color: var(--jj-primary);
  border: 1px solid var(--jj-primary);
}

.jj-btn-secondary:hover {
  background: var(--jj-primary-bg-light);
  color: var(--jj-primary-dark);
}

/* ============================================================
   CARD (Phase 4-5 で精緻化)
   ============================================================ */

.jj-card {
  background: var(--jj-bg-card);
  border: 1px solid var(--jj-border-light);
  border-radius: var(--jj-radius-lg);
  padding: var(--jj-space-6);
}

/* ============================================================
   HEADER / FOOTER ベーススタイル (枠のみ)
   ============================================================ */

.jj-site-header {
  background: var(--jj-bg-white);
  border-bottom: 1px solid var(--jj-border-light);
  /* v1.2.5: 極薄シャドウで現代的な整理感を追加。強い浮遊感ではなく、奥行きのヒントだけ。 */
  box-shadow: var(--jj-shadow-xs);
}

.jj-site-header-inner {
  display: flex;
  align-items: center;
  gap: var(--jj-space-6);
  padding-block: var(--jj-space-4);
  /*
   * モバイル時のメガナビリスト (position:absolute) の配置基準。
   * .jj-mega-nav はモバイルで position:static に切り替えるため、
   * nav-list はここを基準に header-inner 全幅で展開される。
   * PC では他要素に影響しない (PC のメガパネルは .jj-mega-nav を基準にしている)。
   */
  position: relative;
}

/* 3 領域レイアウト: brand (左) / nav (中央・伸縮) / CTA (右) */
.jj-site-header-brand {
  flex: 0 0 auto;
}
.jj-site-nav {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
  min-width: 0;
}
.jj-site-header-cta {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  gap: var(--jj-space-3);
}

.jj-site-logo {
  display: inline-flex;
  align-items: center;
  font-weight: var(--jj-font-bold);
  font-size: var(--jj-text-lg);
  color: var(--jj-text-primary);
  text-decoration: none;
  letter-spacing: 0.01em;
}

.jj-site-logo:hover {
  color: var(--jj-primary);
}

/* ----- Header / Footer logo image (Phase 7 Part 1 / C 案: 比率を尊重) -----
   重要画像 (ロゴ・人・現場) は object-fit: cover を強制せず、
   width: auto + height: 固定 で本来の比率を保つ。 */
.jj-site-logo-img img,
.the-custom-logo-link img,
.custom-logo-link img {
  display: block;
  width: auto;
  height: 40px;
  max-width: 220px;
}
@media (max-width: 767.98px) {
  .jj-site-logo-img img,
  .the-custom-logo-link img,
  .custom-logo-link img {
    height: 32px;
    max-width: 180px;
  }
}

.jj-footer-info-logo {
  display: inline-block;
  margin: 0 0 16px;
  line-height: 0;
}
.jj-footer-info-logo img {
  display: block;
  width: auto;
  height: 36px;
  max-width: 200px;
}

/* .jj-site-nav は上の 3 領域レイアウトで定義済み。本セクションは枠のみ */

/* ============================================================
   MEGA MENU (Phase 3 / v1.4 §4)
   - role="menu" / role="menuitem" 不使用
   - キーボードのみで完結 (詳細ロジックは assets/js/mega-menu.js)
   - PC: ホバー/クリックでパネル展開 (position:absolute)
   - モバイル (<=1023px): ハンバーガー + アコーディオン (position:static)
   ============================================================ */

/* hidden 属性のダブル防御 (CSS で潰されない保険) */
.jj-mega-nav [hidden] {
  display: none !important;
}

/* ナビ全体 */
.jj-mega-nav {
  position: relative;
  display: flex;
  align-items: center;
}

/* PC ナビリスト */
.jj-mega-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: var(--jj-space-2);
}

.jj-mega-nav-item {
  position: relative;
}

/* トリガーボタン / 単一リンク 共通 */
.jj-mega-nav-trigger,
.jj-mega-nav-link {
  display: inline-flex;
  align-items: center;
  gap: var(--jj-space-2);
  min-height: 48px;             /* タップ領域 a11y */
  padding: var(--jj-space-2) var(--jj-space-4);
  background: transparent;
  border: 0;
  border-radius: var(--jj-radius-md);
  color: var(--jj-text-primary);
  font-family: inherit;
  font-size: var(--jj-text-md);
  font-weight: var(--jj-font-medium);
  line-height: var(--jj-leading-normal);
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--jj-transition-fast),
              color var(--jj-transition-fast);
}

.jj-mega-nav-trigger:hover,
.jj-mega-nav-link:hover {
  background: var(--jj-primary-bg-light);
  color: var(--jj-primary);
}

/* フォーカスリング (a11y 必須) */
.jj-mega-nav-trigger:focus-visible,
.jj-mega-nav-link:focus-visible,
.jj-mega-toggle:focus-visible,
.jj-mega-panel a:focus-visible {
  outline: var(--jj-focus-outline);
  outline-offset: var(--jj-focus-outline-offset);
}

/* 開状態のトリガー */
.jj-mega-nav-trigger.is-open {
  background: var(--jj-primary-bg-light);
  color: var(--jj-primary);
}

/* シェブロンアイコン */
.jj-mega-nav-icon {
  flex-shrink: 0;
  transition: transform var(--jj-transition-fast);
}

.jj-mega-nav-trigger.is-open .jj-mega-nav-icon {
  transform: rotate(180deg);
}

/* メガパネル (PC) */
.jj-mega-panel {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: var(--jj-z-dropdown);
  min-width: 240px;
  margin-top: var(--jj-space-2);
  padding: var(--jj-space-3);
  background: var(--jj-bg-white);
  border: 1px solid var(--jj-border-light);
  border-radius: var(--jj-radius-lg);
  box-shadow: var(--jj-shadow-lg);
}

/* ワイドメガ (3 列 + Featured): nav 全幅へ展開する */
.jj-mega-nav-item--wide { position: static; }
.jj-mega-panel--wide {
  left: 0;
  right: 0;
  min-width: 0;
  padding: var(--jj-space-8);
}

/* 3 列 + Featured */
.jj-mega-panel-cols {
  display: grid;
  gap: var(--jj-space-8);
  grid-template-columns: repeat(3, minmax(0, 1fr)) minmax(0, 1.1fr);
}

.jj-mega-col {
  min-width: 0;
}

.jj-mega-col-heading {
  margin: 0 0 var(--jj-space-3);
  padding-bottom: var(--jj-space-2);
  border-bottom: 1px solid var(--jj-border-light);
  color: var(--jj-text-muted);
  font-size: var(--jj-text-sm);
  font-weight: var(--jj-font-bold);
  letter-spacing: 0.04em;
}

/* リンクリスト (単一列メガでも 3 列メガでも共通) */
.jj-mega-panel-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--jj-space-1);
}

.jj-mega-panel-list a {
  display: flex;
  align-items: center;
  gap: var(--jj-space-2);
  min-height: 44px;
  padding: var(--jj-space-2) var(--jj-space-3);
  border-radius: var(--jj-radius-md);
  color: var(--jj-text-primary);
  font-size: var(--jj-text-md);
  text-decoration: none;
  transition: background-color var(--jj-transition-fast),
              color var(--jj-transition-fast);
}

.jj-mega-panel-list a:hover {
  background: var(--jj-primary-bg-light);
  color: var(--jj-primary);
}

/* 「新制度」タグ */
.jj-tag-new {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--jj-space-2);
  background: var(--jj-primary);
  color: var(--jj-text-on-primary);
  font-size: var(--jj-text-xs);
  font-weight: var(--jj-font-semibold);
  border-radius: var(--jj-radius-sm);
  letter-spacing: 0.04em;
}

/* 「すべての職種を見る」(列内末尾の補助 CTA リンク) */
.jj-mega-link-all {
  font-weight: var(--jj-font-semibold);
  color: var(--jj-primary) !important;
}

/* Featured 列 */
.jj-mega-col-featured {
  padding: var(--jj-space-5);
  background: var(--jj-primary-bg-light);
  border-radius: var(--jj-radius-lg);
  display: flex;
  flex-direction: column;
}

.jj-mega-col-eyebrow {
  margin: 0 0 var(--jj-space-2);
  color: var(--jj-primary);
  font-size: var(--jj-text-xs);
  font-weight: var(--jj-font-bold);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.jj-mega-col-title {
  margin: 0 0 var(--jj-space-3);
  font-size: var(--jj-text-lg);
  font-weight: var(--jj-font-bold);
  line-height: var(--jj-leading-tight);
  color: var(--jj-text-primary);
}

.jj-mega-col-desc {
  margin: 0 0 var(--jj-space-4);
  font-size: var(--jj-text-sm);
  line-height: var(--jj-leading-relaxed);
  color: var(--jj-text-secondary);
}

.jj-mega-col-cta {
  display: inline-flex;
  align-items: center;
  margin-top: auto;
  padding: var(--jj-space-2) 0;
  color: var(--jj-primary);
  font-size: var(--jj-text-md);
  font-weight: var(--jj-font-semibold);
  text-decoration: none;
  transition: color var(--jj-transition-fast);
}

.jj-mega-col-cta:hover {
  color: var(--jj-primary-dark);
}

/* パネル下端の「全体像 → /jinzai/」リンク */
.jj-mega-panel-overall {
  margin-top: var(--jj-space-6);
  padding-top: var(--jj-space-4);
  border-top: 1px solid var(--jj-border-light);
  text-align: right;
}

.jj-mega-overall-link {
  display: inline-flex;
  align-items: center;
  gap: var(--jj-space-2);
  min-height: 44px;
  padding: var(--jj-space-2) var(--jj-space-3);
  color: var(--jj-primary);
  font-size: var(--jj-text-md);
  font-weight: var(--jj-font-semibold);
  text-decoration: none;
  border-radius: var(--jj-radius-md);
  transition: background-color var(--jj-transition-fast),
              color var(--jj-transition-fast);
}

.jj-mega-overall-link:hover {
  background: var(--jj-primary-bg-light);
  color: var(--jj-primary-dark);
}

.jj-mega-overall-link:focus-visible {
  outline: var(--jj-focus-outline);
  outline-offset: var(--jj-focus-outline-offset);
}

/* ハンバーガー (PC では非表示) */
.jj-mega-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: var(--jj-radius-md);
  color: var(--jj-text-primary);
  cursor: pointer;
}

.jj-mega-toggle-icon {
  display: inline-block;
  width: 22px;
  height: 16px;
  position: relative;
}

.jj-mega-toggle-icon span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
  transition: transform var(--jj-transition-fast),
              opacity var(--jj-transition-fast),
              top var(--jj-transition-fast);
}

.jj-mega-toggle-icon span:nth-child(1) { top: 0; }
.jj-mega-toggle-icon span:nth-child(2) { top: 7px; }
.jj-mega-toggle-icon span:nth-child(3) { top: 14px; }

.jj-mega-toggle[aria-expanded="true"] .jj-mega-toggle-icon span:nth-child(1) {
  top: 7px;
  transform: rotate(45deg);
}
.jj-mega-toggle[aria-expanded="true"] .jj-mega-toggle-icon span:nth-child(2) {
  opacity: 0;
}
.jj-mega-toggle[aria-expanded="true"] .jj-mega-toggle-icon span:nth-child(3) {
  top: 7px;
  transform: rotate(-45deg);
}

/* ============================================================
   モバイル (~1023px): ハンバーガー + アコーディオン
   ============================================================ */
@media (max-width: 1023.98px) {

  /* CTA はモバイルでも表示 (ハンバーガーの右隣に並ぶ) */
  .jj-site-header-cta-btn {
    padding: var(--jj-space-2) var(--jj-space-4);
    font-size: var(--jj-text-sm);
  }

  .jj-mega-toggle {
    display: inline-flex;
  }

  /* nav 領域は伸縮しない (CTA を確実に右に置く) */
  .jj-site-nav {
    flex: 0 0 auto;
    justify-content: flex-end;
  }

  /*
   * モバイルでは .jj-mega-nav の幅がハンバーガー (48px) まで縮むため、
   * nav-list の position:absolute 基準を .jj-site-header-inner に譲る。
   * これにより nav-list は header-inner 全幅で展開され、48px 幅に潰れない。
   */
  .jj-mega-nav {
    position: static;
  }

  /* ナビリストはハンバーガーが開いた時のみ表示 */
  .jj-mega-nav-list {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: var(--jj-z-dropdown);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    margin-top: var(--jj-space-2);
    padding: var(--jj-space-3);
    background: var(--jj-bg-white);
    border: 1px solid var(--jj-border-light);
    border-radius: var(--jj-radius-lg);
    box-shadow: var(--jj-shadow-lg);
    max-height: calc(100vh - 80px);
    overflow-y: auto;
  }

  .jj-mega-nav.is-mobile-open .jj-mega-nav-list {
    display: flex;
  }

  .jj-mega-nav-trigger,
  .jj-mega-nav-link {
    width: 100%;
    justify-content: space-between;
    border-radius: var(--jj-radius-md);
  }

  /* メガパネルは accordion (静的位置) に切り替え */
  .jj-mega-panel {
    position: static;
    margin-top: var(--jj-space-1);
    margin-bottom: var(--jj-space-2);
    padding: var(--jj-space-2);
    border: 0;
    border-radius: var(--jj-radius-md);
    background: var(--jj-bg-section-alt);
    box-shadow: none;
    min-width: 0;
  }

  /* ワイドメガもモバイルでは静的位置 + 縦スタック */
  .jj-mega-panel--wide {
    padding: var(--jj-space-3);
  }

  .jj-mega-panel-cols {
    display: flex;
    flex-direction: column;
    gap: var(--jj-space-4);
  }

  .jj-mega-col-featured {
    order: 99;        /* Featured 列はスタック末尾に回す */
  }

  .jj-mega-panel-overall {
    text-align: center;
  }
}

/* ============================================================
   prefers-reduced-motion: ユーザーが動きを抑えたい場合
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .jj-mega-nav-trigger,
  .jj-mega-nav-link,
  .jj-mega-nav-icon,
  .jj-mega-panel-list a,
  .jj-mega-toggle-icon span,
  .jj-mega-col-cta,
  .jj-mega-overall-link {
    transition: none !important;
  }

  /* v1.2.5: ボタンの hover translateY も抑制 */
  .jj-btn-primary:hover,
  .jj-btn-secondary:hover {
    transform: none;
  }
}

/*
 * Phase 1 由来の単一フッタースタイル (.jj-site-footer / .jj-site-footer-inner)
 * は Phase 6 で 4 パーツ分割 (footer-cta / -sitemap / -info / -bottom) に置換済。
 * 新しい .jj-site-footer / .jj-footer-* 定義は本ファイル後段に集約している。
 */

/* ============================================================
   BREADCRUMB (Phase 5 / 用語集 v1.2)
   - Phase 5 で /strong/ 用に新規追加し、components.css へ昇格
   - 全下層ページで再利用する想定
   - <nav aria-label="パンくずリスト"> + <ol> + 現在地は aria-current="page"
   ============================================================ */

.jj-breadcrumb {
  font-size: 13px;
  line-height: 1.6;
  color: var(--jj-text-mute);
  letter-spacing: 0.02em;
}

.jj-breadcrumb-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.jj-breadcrumb-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.jj-breadcrumb-item a {
  color: var(--jj-text-mute);
  text-decoration: none;
  transition: color var(--jj-transition-fast);
}

.jj-breadcrumb-item a:hover {
  color: var(--jj-blue);
  text-decoration: underline;
}

.jj-breadcrumb-item a:focus-visible {
  outline: var(--jj-focus-outline);
  outline-offset: var(--jj-focus-outline-offset);
  border-radius: 2px;
}

.jj-breadcrumb-sep {
  opacity: 0.4;
  user-select: none;
}

.jj-breadcrumb-current {
  color: var(--jj-text);
  font-weight: var(--jj-font-medium);
}

/* ============================================================
   GENERIC TYPE SCALE (Phase 6)
   - Phase 4 の .jj-fp-h2 / .jj-fp-h3 を Phase 6 で汎用化。
   - .jj-fp-h1 (TOP Hero accent 装飾) と .jj-strong-hero-h1 (思想ページ専用 clamp)
     はページ固有として front-page.css / strong.css に残す。
   - 値は .jj-fp-h2 / .jj-fp-h3 の現行値を完全踏襲し、見た目に影響なし。
   ============================================================ */

.jj-h1 {
  font-size: 48px;
  font-weight: var(--jj-font-black);
  line-height: 1.3;
  letter-spacing: 0.02em;
  margin: 0 0 24px;
}

.jj-h2 {
  font-size: 36px;
  font-weight: var(--jj-font-bold);
  line-height: 1.3;
  margin: 0;
}

.jj-h3 {
  font-size: 22px;
  font-weight: var(--jj-font-bold);
  line-height: 1.4;
  margin: 0 0 12px;
}

.jj-body {
  font-size: 16px;
  font-weight: var(--jj-font-normal);
  line-height: 1.8;
  margin: 0;
}

@media (max-width: 1023.98px) {
  .jj-h1 { font-size: 36px; }
  .jj-h2 { font-size: 28px; }
  .jj-h3 { font-size: 19px; }
}

@media (max-width: 767.98px) {
  .jj-h1 { font-size: 30px; }
  .jj-h2 { font-size: 24px; }
  .jj-h3 { font-size: 18px; }
  .jj-body { font-size: 15px; }
}

/* ============================================================
   CONTAINER VARIANTS
   - .jj-container-narrow: 本文中心ページ (page / single / contact form)
   ============================================================ */

.jj-container-narrow {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 var(--jj-space-4);
}

/* ============================================================
   SECTION HEAD VARIANTS
   - .jj-section-head-tight: 縦詰めの section-head (contact 4 セクション等)
   ============================================================ */

.jj-section-head-tight {
  text-align: center;
  margin-bottom: 32px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================================
   SEARCH FORM (searchform.php 共通)
   ============================================================ */

.jj-searchform {
  display: flex;
  gap: 8px;
  align-items: stretch;
  width: 100%;
  max-width: 560px;
}

.jj-searchform-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 12px 16px;
  font-size: 16px;
  font-family: inherit;
  color: var(--jj-text);
  background: var(--jj-white);
  border: 1px solid var(--jj-gray-300);
  border-radius: var(--jj-r-md);
  transition: border-color var(--jj-transition-fast),
              box-shadow var(--jj-transition-fast);
}

.jj-searchform-input:focus,
.jj-searchform-input:focus-visible {
  outline: none;
  border-color: var(--jj-blue);
  box-shadow: var(--jj-focus-ring);
}

.jj-searchform-submit {
  flex: 0 0 auto;
}

@media (max-width: 480px) {
  .jj-searchform { flex-direction: column; }
  .jj-searchform-submit { width: 100%; justify-content: center; }
}

/* ============================================================
   PAGINATION (paginate_links 出力に被せる)
   ============================================================ */

.jj-pagination {
  margin: 56px 0 24px;
  display: flex;
  justify-content: center;
}

.jj-pagination .page-numbers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.jj-pagination .page-numbers li {
  display: inline-flex;
}

.jj-pagination a.page-numbers,
.jj-pagination span.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 8px 12px;
  font-size: 14px;
  color: var(--jj-text);
  background: var(--jj-white);
  border: 1px solid var(--jj-gray-200);
  border-radius: var(--jj-r-sm);
  text-decoration: none;
  transition: background-color var(--jj-transition-fast),
              border-color var(--jj-transition-fast),
              color var(--jj-transition-fast);
}

.jj-pagination a.page-numbers:hover {
  background: var(--jj-blue-tint);
  border-color: var(--jj-blue);
  color: var(--jj-blue);
}

.jj-pagination a.page-numbers:focus-visible {
  outline: var(--jj-focus-outline);
  outline-offset: var(--jj-focus-outline-offset);
}

.jj-pagination span.page-numbers.current,
.jj-pagination span.page-numbers[aria-current="page"] {
  background: var(--jj-blue);
  border-color: var(--jj-blue);
  color: var(--jj-white);
  font-weight: var(--jj-font-bold);
}

.jj-pagination .page-numbers.dots {
  border-color: transparent;
  color: var(--jj-text-mute);
}

/* ============================================================
   NOT FOUND (404 / 0 件検索 共通)
   ============================================================ */

.jj-not-found {
  padding: 96px 0;
  text-align: center;
}

.jj-not-found-h {
  margin: 0 0 24px;
}

.jj-not-found-lede {
  font-size: 16px;
  line-height: 1.9;
  color: var(--jj-text-mute);
  margin: 0 auto 32px;
  max-width: 36em;
}

.jj-not-found-search,
.jj-not-found-search-form {
  display: flex;
  justify-content: center;
  margin-bottom: 32px;
}

.jj-not-found-links {
  margin-top: 16px;
}

.jj-not-found-link-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: inline-flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-start;
  text-align: left;
}

@media (max-width: 767.98px) {
  .jj-not-found { padding: 64px 0; }
}

/* ============================================================
   PAGE CONTENT (Gutenberg ブロック共通スタイル)
   - page.php / single.php の本文エリアで使用
   - h2/h3/p/ul/ol/blockquote/img/code 等の最低限スタイル
   ============================================================ */

.jj-page-content {
  font-size: 16px;
  line-height: 1.9;
  color: var(--jj-text);
}

.jj-page-content > * + * {
  margin-top: 24px;
}

.jj-page-content h2 {
  font-size: 28px;
  font-weight: var(--jj-font-bold);
  line-height: 1.4;
  margin-top: 56px;
  margin-bottom: 16px;
}

.jj-page-content h3 {
  font-size: 22px;
  font-weight: var(--jj-font-bold);
  line-height: 1.4;
  margin-top: 40px;
  margin-bottom: 12px;
}

.jj-page-content h4 {
  font-size: 18px;
  font-weight: var(--jj-font-bold);
  line-height: 1.4;
  margin-top: 32px;
  margin-bottom: 8px;
}

.jj-page-content p {
  margin: 0;
}

.jj-page-content a {
  color: var(--jj-blue);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.jj-page-content a:hover {
  color: var(--jj-blue-dark);
}

.jj-page-content ul,
.jj-page-content ol {
  padding-left: 1.5em;
  margin: 0;
}

.jj-page-content ul li,
.jj-page-content ol li {
  margin-top: 8px;
}

.jj-page-content blockquote {
  margin: 0;
  padding: 16px 20px;
  border-left: 3px solid var(--jj-blue);
  background: var(--jj-gray-50);
  color: var(--jj-text);
  font-style: normal;
}

.jj-page-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--jj-r-md);
}

.jj-page-content figure {
  margin: 0;
}

.jj-page-content figcaption {
  font-size: 13px;
  color: var(--jj-text-mute);
  margin-top: 8px;
  text-align: center;
}

.jj-page-content code {
  padding: 2px 6px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.9em;
  background: var(--jj-gray-50);
  border: 1px solid var(--jj-gray-200);
  border-radius: 4px;
}

.jj-page-content pre {
  padding: 16px;
  overflow-x: auto;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 14px;
  line-height: 1.6;
  background: var(--jj-gray-50);
  border: 1px solid var(--jj-gray-200);
  border-radius: var(--jj-r-md);
}

.jj-page-content pre code {
  padding: 0;
  background: none;
  border: none;
}

/* ============================================================
   FORM COMMON (.jj-form-* / WPForms 出力にも被せる)
   ============================================================ */

.jj-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 20px;
}

.jj-form-label {
  font-size: 14px;
  font-weight: var(--jj-font-medium);
  color: var(--jj-text);
}

.jj-form-required {
  color: var(--jj-orange);
  font-weight: var(--jj-font-bold);
  margin-left: 4px;
}

.jj-form-input,
.jj-form-textarea,
.jj-form-select {
  padding: 12px 14px;
  font-size: 16px;
  font-family: inherit;
  color: var(--jj-text);
  background: var(--jj-white);
  border: 1px solid var(--jj-gray-300);
  border-radius: var(--jj-r-md);
  transition: border-color var(--jj-transition-fast),
              box-shadow var(--jj-transition-fast);
}

.jj-form-input:focus,
.jj-form-textarea:focus,
.jj-form-select:focus,
.jj-form-input:focus-visible,
.jj-form-textarea:focus-visible,
.jj-form-select:focus-visible {
  outline: none;
  border-color: var(--jj-blue);
  box-shadow: var(--jj-focus-ring);
}

.jj-form-textarea {
  min-height: 140px;
  resize: vertical;
  line-height: 1.7;
}

.jj-form-error {
  color: #B22D3C;
  font-size: 13px;
  margin-top: 4px;
}

/* ============================================================
   FOOTER (Phase 6 で 4 パーツ分割)
   - .jj-site-footer 全体
   - .jj-footer-cta / -sitemap / -info / -bottom
   ============================================================ */

.jj-site-footer {
  background: var(--jj-text);
  color: rgba(255, 255, 255, 0.78);
  margin-top: 0;
  font-size: 14px;
  border-top: none;
}

.jj-site-footer a {
  color: rgba(255, 255, 255, 0.85);
  text-decoration: none;
  transition: color var(--jj-transition-fast);
}

.jj-site-footer a:hover { color: var(--jj-white); }
.jj-site-footer a:focus-visible {
  outline: 2px solid var(--jj-white);
  outline-offset: 2px;
}

/* ----- Footer CTA (背景は明るく、本体フッターと差別化) ----- */
.jj-footer-cta {
  background: var(--jj-gray-50);
  color: var(--jj-text);
  padding: 80px 0;
  text-align: center;
}

.jj-footer-cta-h {
  margin: 0 0 16px;
  text-align: center;
}

.jj-footer-cta-lede {
  font-size: 16px;
  line-height: 1.9;
  color: var(--jj-text-mute);
  margin: 0 auto 32px;
  max-width: 36em;
}

.jj-footer-cta-btns {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 16px;
  justify-content: center;
}

/* ----- Footer Sitemap ----- */
.jj-footer-sitemap {
  padding: 64px 0 32px;
}

.jj-footer-sitemap-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
}

.jj-footer-sitemap-col {
  min-width: 0;
}

.jj-footer-sitemap-h {
  font-size: 13px;
  font-weight: var(--jj-font-bold);
  color: var(--jj-white);
  letter-spacing: 0.06em;
  margin: 0 0 16px;
}

.jj-footer-sitemap-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* ----- Footer Info ----- */
.jj-footer-info {
  padding: 32px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.jj-footer-info-grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 48px;
}

.jj-footer-info-h {
  font-size: 13px;
  font-weight: var(--jj-font-bold);
  color: var(--jj-white);
  letter-spacing: 0.04em;
  margin: 0 0 12px;
}

.jj-footer-info-co {
  font-size: 13px;
  line-height: 1.8;
  color: rgba(255, 255, 255, 0.6);
  margin: 0;
}

.jj-footer-info-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 14px;
}

.jj-footer-info-list li {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: baseline;
}

.jj-footer-info-key {
  color: rgba(255, 255, 255, 0.55);
  font-size: 12px;
  letter-spacing: 0.04em;
  min-width: 70px;
}

/* ----- Footer Bottom ----- */
.jj-footer-bottom {
  padding: 24px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 12px;
  color: rgba(255, 255, 255, 0.5);
}

.jj-footer-bottom-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.jj-footer-copy { color: rgba(255, 255, 255, 0.5); }

.jj-footer-legal {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 12px;
}

.jj-footer-legal a { color: rgba(255, 255, 255, 0.6); }

@media (max-width: 767.98px) {
  .jj-footer-cta { padding: 56px 0; }
  .jj-footer-sitemap { padding: 48px 0 24px; }
  .jj-footer-sitemap-grid { grid-template-columns: 1fr; gap: 32px; }
  .jj-footer-info-grid { grid-template-columns: 1fr; gap: 32px; }
  .jj-footer-bottom-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .jj-footer-cta-btns .jj-btn {
    width: 100%;
    justify-content: center;
  }
}
