/*
 Theme Name: Cocoon Child Master
 Theme URI: https://wp-cocoon.com/
 Description: Cocoon 子テーマ（サポBAN 用カスタム）
 Author: サポBAN
 Template: cocoon-master
 Version: 1.0.0
*/

/* =====================================================
   サポBAN 共通UI / デザイン統合CSS（一本化）
   - 全画面共通：左=本文 / 右=サイドバー（PCのみ2カラム）
   - .sb-*：共通コンポーネント
   - マイページ専用っぽいものは .sb-mypage 配下に限定
===================================================== */

/* =====================================================
   0) 崩れ防止（共通）
===================================================== */
*,
*::before,
*::after { box-sizing: border-box; }

img, iframe, table, input, select, textarea {
  max-width: 100%;
}

/* =====================================================
   1) 全画面レイアウト固定（Cocoon：左=main / 右=sidebar）
   ※PCのみ2カラム固定、スマホは縦積み
===================================================== */
@media (min-width: 992px) {
  #content-in {
    display: flex;
    align-items: flex-start;
    gap: 24px;
  }
  #main {
    order: 1;
    flex: 1 1 auto;
    min-width: 0; /* 長文やフォームで崩れるのを防止 */
  }
  #sidebar {
    order: 2;
    flex: 0 0 320px;
  }
}
@media (max-width: 991px) {
  #content-in { display: block; }
}

/* =====================================================
   2) カラーパレット（CSS変数）
===================================================== */
:root {
  --sb-color-bg: #ffffff;
  --sb-color-text: #222222;
  --sb-color-subtext: #666666;

  --sb-color-primary: #2563eb;
  --sb-color-secondary: #475569;
  --sb-color-danger: #dc2626;

  --sb-color-border: #e5e7eb;
  --sb-color-bg-light: #f9fafb;
}

/* =====================================================
   3) フォント・基本テキスト
===================================================== */
body {
  font-family:
    -apple-system,
    BlinkMacSystemFont,
    "Hiragino Kaku Gothic ProN",
    "Noto Sans JP",
    "Yu Gothic",
    "Meiryo",
    sans-serif;

  color: var(--sb-color-text);
  line-height: 1.7;
}

h1, h2, h3 {
  font-weight: 600;
  line-height: 1.4;
}

/* =====================================================
   4) ボタン（共通）※重複定義を排除
===================================================== */
.sb-btn {
  display: inline-block;
  padding: 0.6em 1.2em;
  font-size: 0.95rem;
  border-radius: 6px;
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.2s ease;
  text-align: center;
}

.sb-btn-primary { background: var(--sb-color-primary); color: #fff; }
.sb-btn-secondary { background: var(--sb-color-secondary); color: #fff; }
.sb-btn-danger { background: var(--sb-color-danger); color: #fff; }

.sb-btn-outline {
  background: #fff;
  color: var(--sb-color-primary);
  border-color: var(--sb-color-primary);
}

.sb-btn:hover { opacity: 0.88; }

/* 小さいボタン（必要時だけ） */
.sb-btn-small { font-size: 0.85rem; padding: 0.45em 0.8em; }

/* =====================================================
   5) フォーム（共通）
===================================================== */
.sb-form label {
  display: block;
  margin-bottom: 12px;
  font-weight: 600;
}

.sb-form input[type="text"],
.sb-form input[type="email"],
.sb-form input[type="password"],
.sb-form textarea,
.sb-form select {
  width: 100%;
  padding: 0.6em;
  border: 1px solid var(--sb-color-border);
  border-radius: 6px;
  font-size: 0.95rem;
  margin-top: 6px;
}

.sb-form textarea {
  resize: vertical;
  min-height: 120px;
}

/* =====================================================
   6) 通知メッセージ（共通）
===================================================== */
.sb-msg-success {
  background: #e6f4ea;
  color: #188038;
  padding: 12px;
  border-radius: 6px;
  margin-bottom: 16px;
  font-size: 14px;
}

.sb-msg-error {
  background: #fce8e6;
  color: #d93025;
  padding: 12px;
  border-radius: 6px;
  margin-bottom: 16px;
  font-size: 14px;
}

/* =====================================================
   7) 募集一覧（共通）
   - public の member/battle 一覧でも使える共通カード
===================================================== */
.sb-recruit-list {
  max-width: 900px;
  margin: 0 auto;
  padding: 1rem;
}

.sb-recruit-items {
  list-style: none;
  padding: 0;
  margin: 0;
}

.sb-recruit-card {
  border: 1px solid var(--sb-color-border);
  border-radius: 10px;
  padding: 1rem;
  margin-bottom: 1rem;
  background: #fff;
}

@media (hover: hover) {
  .sb-recruit-card:hover { background: var(--sb-color-bg-light); }
}

.sb-recruit-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  word-break: break-word;
}

.sb-recruit-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem 1rem;
  font-size: 0.85rem;
  color: var(--sb-color-subtext);
  margin-top: 0.25rem;
}

.sb-recruit-actions {
  margin-top: 0.75rem;
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

/* 閲覧済/お気に入り（共通） */
.sb-recruit-card.is-viewed { opacity: 0.7; }
.sb-recruit-card.is-favorite {
  border-color: var(--sb-color-primary);
  background: #f8faff;
}

/* =====================================================
   8) 募集一覧：検索フォームUI（共通）
===================================================== */
.sb-filter-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 1.5rem;
  font-size: 0.9rem;
}

.sb-filter-form select[name="age_from"],
.sb-filter-form select[name="age_to"] {
  width: auto;
  min-width: 120px;
}

.sb-filter-form select[name="area_pref"],
.sb-filter-form select[name="seriousness"],
.sb-filter-form input[name="keyword"] {
  min-width: 160px;
}

.sb-clear-filter {
  display: inline-block;
  text-decoration: none;
  padding: 0.6em 0.8em;
}

@media (max-width: 768px) {
  .sb-filter-form { align-items: stretch; }
  .sb-filter-form select,
  .sb-filter-form input,
  .sb-filter-form button,
  .sb-filter-form .sb-clear-filter { width: 100%; }
}

/* =====================================================
   9) 募集詳細（共通）
===================================================== */
#sb-recruit-single {
  max-width: 900px;
  margin: 0 auto;
  padding: 1.5rem 1rem;
}

#sb-recruit-single h1 {
  font-size: 1.4rem;
  margin-bottom: 0.5rem;
}

.sb-recruit-content {
  margin: 1.5rem 0;
  line-height: 1.8;
}

/* =====================================================
   10) メッセージ（共通：LINE風）
===================================================== */
#sb-message-thread {
  max-width: 800px;
  margin: 0 auto;
  padding: 1.5rem 1rem;
}

.sb-message-list {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
}

.sb-message {
  margin-bottom: 1rem;
  max-width: 80%;
}

.sb-message.is-mine {
  margin-left: auto;
  text-align: right;
}

.sb-message-body {
  padding: 0.75rem;
  border-radius: 10px;
  line-height: 1.6;
  word-break: break-word;
}

.sb-message.is-mine .sb-message-body {
  background: var(--sb-color-primary);
  color: #fff;
}

.sb-message.is-other .sb-message-body {
  background: var(--sb-color-bg-light);
  border: 1px solid var(--sb-color-border);
}

.sb-message-meta {
  font-size: 0.75rem;
  color: var(--sb-color-subtext);
  margin-top: 0.25rem;
}

@media (max-width: 768px) {
  .sb-message { max-width: 100%; }
}

/* =====================================================
   11) マイページ（共通）
   ※他ページに影響させないため .sb-mypage 配下に限定
===================================================== */
.sb-mypage {
  background: #f7f7f7;
  min-height: 60vh;
  padding: 16px;
  font-size: 14px;
  line-height: 1.6;
}

.sb-mypage a { color: var(--sb-color-primary); text-decoration: none; }
.sb-mypage a:hover { text-decoration: underline; }

.sb-mypage-container {
  max-width: 1100px;
  margin: 0 auto;
}

.sb-mypage-layout {
  display: flex;
  gap: 20px;
}

.sb-mypage-sidebar {
  width: 220px;
  flex-shrink: 0;
}

.sb-mypage-sidebar ul { list-style: none; padding: 0; margin: 0; }
.sb-mypage-sidebar li { margin-bottom: 6px; }

.sb-mypage-sidebar a {
  display: block;
  padding: 10px 12px;
  background: #fff;
  border-radius: 8px;
  color: #333;
}

.sb-mypage-sidebar a.is-active {
  background: var(--sb-color-primary);
  color: #fff;
}

.sb-mypage-main { flex: 1; min-width: 0; }

@media (max-width: 768px) {
  .sb-mypage-layout { flex-direction: column; }
  .sb-mypage-sidebar { width: 100%; }
}

/* =====================================================
   12) スマホ最適化（共通）
===================================================== */
@media (max-width: 768px) {
  .sb-btn { width: 100%; }
}
/* ===== page header ===== */
.sb-page-header {
  padding: 24px 0 12px;
}
.sb-page-header__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 16px;
}
.sb-page-title {
  font-size: 1.8rem;
  margin: 0 0 6px;
}
.sb-page-subtitle {
  margin: 0;
  color: var(--sb-color-subtext);
}

/* ===== page body ===== */
.sb-page-body {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 16px 24px;
}

/* ===== filter card ===== */
.sb-card--filter {
  background: #fff;
  border: 1px solid var(--sb-color-border);
  border-radius: 12px;
  padding: 16px;
  margin: 12px 0 16px;
}

.sb-filter__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.sb-field { width: 100%; }
.sb-field--tilde {
  display: none;
  align-self: end;
  color: var(--sb-color-subtext);
  padding-bottom: 10px;
}
.sb-field--grow { width: 100%; }

.sb-label {
  display: block;
  font-size: 0.85rem;
  color: var(--sb-color-subtext);
  margin-bottom: 6px;
}

/* actions */
.sb-filter__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 6px;
}

/* PC：年齢を横並び */
@media (min-width: 768px) {
  .sb-filter__row:first-child {
    grid-template-columns: 1fr auto 1fr;
    align-items: end;
  }
  .sb-field--tilde { display: block; }
  .sb-filter__row:nth-child(2) {
    grid-template-columns: 1fr 1fr;
  }
}

/* ===== result head ===== */
.sb-result-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 6px 0 10px;
}
.sb-result-count {
  margin: 0;
  font-weight: 600;
}
.sb-note--warn {
  margin: 0;
}

/* ===== recruit grid ===== */
.sb-recruit-grid {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

@media (min-width: 768px) {
  .sb-recruit-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.sb-recruit-card2 {
  border: 1px solid var(--sb-color-border);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.sb-recruit-card2__link {
  display: block;
  padding: 14px;
  text-decoration: none;
  color: inherit;
}

.sb-recruit-card2__title {
  margin: 0 0 10px;
  font-size: 1.05rem;
  line-height: 1.4;
  word-break: break-word;
}

.sb-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sb-chip {
  display: inline-block;
  font-size: 0.85rem;
  color: var(--sb-color-subtext);
  background: var(--sb-color-bg-light);
  border: 1px solid var(--sb-color-border);
  border-radius: 999px;
  padding: 6px 10px;
}

.sb-recruit-card2__foot {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.sb-muted { color: var(--sb-color-subtext); font-size: 0.85rem; }
.sb-more  { color: var(--sb-color-primary); font-weight: 600; }

@media (hover:hover) {
  .sb-recruit-card2:hover {
    background: var(--sb-color-bg-light);
  }
}
/* =====================================================
   サポBAN：トップページ（プロ見え共通）
===================================================== */

.sb-container{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 16px;
}

.sb-page{ background: var(--sb-color-bg); }

/* HERO */
.sb-hero{
  padding: 56px 0;
  background: linear-gradient(180deg, #f9fafb 0%, #ffffff 100%);
  border-bottom: 1px solid var(--sb-color-border);
}
.sb-hero__inner{
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
.sb-hero__eyebrow{
  color: var(--sb-color-subtext);
  font-weight: 600;
  margin: 0 0 8px;
}
.sb-hero__title{
  font-size: 2.1rem;
  line-height: 1.25;
  margin: 0 0 12px;
}
.sb-hero__lead{
  color: var(--sb-color-subtext);
  margin: 0 0 18px;
}
.sb-hero__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.sb-hero__meta{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.sb-hero__meta-item{
  background: #fff;
  border: 1px solid var(--sb-color-border);
  border-radius: 10px;
  padding: 10px 12px;
}
.sb-hero__meta-label{
  font-size: 12px;
  color: var(--sb-color-subtext);
  display: block;
}
.sb-hero__meta-value{
  font-weight: 600;
  display: block;
  margin-top: 2px;
}
.sb-only-desktop{ display: inline; }

/* Card */
.sb-card{
  background: #fff;
  border: 1px solid var(--sb-color-border);
  border-radius: 12px;
  padding: 16px;
}
.sb-card__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.sb-card__title{
  font-size: 1.1rem;
  margin: 0;
}
.sb-card__desc{
  color: var(--sb-color-subtext);
  margin: 8px 0 12px;
}
.sb-card__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.sb-card__note{
  margin-top: 12px;
  color: var(--sb-color-subtext);
  font-size: 0.9rem;
}
.sb-card__subactions{
  margin-top: 8px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.sb-link{
  color: var(--sb-color-primary);
  text-decoration: none;
}
.sb-link:hover{ text-decoration: underline; }

/* Sections */
.sb-section{
  padding: 40px 0;
}
.sb-section--alt{
  background: var(--sb-color-bg-light);
  border-top: 1px solid var(--sb-color-border);
  border-bottom: 1px solid var(--sb-color-border);
}
.sb-section__head{
  margin-bottom: 16px;
}
.sb-section__title{
  font-size: 1.4rem;
  margin: 0 0 6px;
}
.sb-section__subtitle{
  margin: 0;
  color: var(--sb-color-subtext);
}

/* Grid */
.sb-grid-2{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

/* List */
.sb-list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}
.sb-list__item{
  border: 1px solid var(--sb-color-border);
  border-radius: 10px;
  overflow: hidden;
}
.sb-list__link{
  display: block;
  padding: 12px;
  color: var(--sb-color-text);
  text-decoration: none;
}
.sb-list__link:hover{
  background: var(--sb-color-bg-light);
}
.sb-list__title{
  font-weight: 700;
  margin-bottom: 8px;
}
.sb-list__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sb-chip{
  display: inline-block;
  font-size: 12px;
  color: var(--sb-color-subtext);
  background: #f8fafc;
  border: 1px solid var(--sb-color-border);
  padding: 4px 8px;
  border-radius: 999px;
}
.sb-list__foot{
  margin-top: 10px;
  display: flex;
  justify-content: space-between;
  color: var(--sb-color-subtext);
  font-size: 12px;
}
.sb-more{ color: var(--sb-color-primary); font-weight: 600; }
.sb-muted{ color: var(--sb-color-subtext); }

/* Features */
.sb-feature-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.sb-feature{
  background: #fff;
  border: 1px solid var(--sb-color-border);
  border-radius: 12px;
  padding: 16px;
}
.sb-feature__title{
  margin: 0 0 6px;
  font-size: 1.05rem;
}
.sb-feature__text{
  margin: 0;
  color: var(--sb-color-subtext);
}

/* CTA */
.sb-cta{
  padding: 44px 0;
}
.sb-cta__inner{
  background: #fff;
  border: 1px solid var(--sb-color-border);
  border-radius: 14px;
  padding: 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  align-items: center;
}
.sb-cta__title{
  margin: 0 0 6px;
  font-size: 1.35rem;
}
.sb-cta__text{
  margin: 0;
  color: var(--sb-color-subtext);
}
.sb-cta__actions{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Responsive */
@media (max-width: 900px){
  .sb-hero__inner{ grid-template-columns: 1fr; }
  .sb-only-desktop{ display: none; }
  .sb-grid-2{ grid-template-columns: 1fr; }
  .sb-feature-grid{ grid-template-columns: 1fr; }
  .sb-cta__inner{ grid-template-columns: 1fr; }
  .sb-cta__actions{ justify-content: flex-start; }
}
.sb-check-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px 10px;
}
@media (max-width:768px){
  .sb-check-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); }
}
@media (max-width:480px){
  .sb-check-grid{ grid-template-columns:1fr; }
}
/* =========================
   Member Edit：フォーム整列（横長抑制）
========================= */

.sb-form-grid{
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* 2列行：PCは2列、スマホは1列 */
.sb-row{
  display: grid;
  gap: 12px;
}
.sb-row-2{
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 768px){
  .sb-row-2{ grid-template-columns: 1fr; }
}

/* select を横長にしない：上限幅を付ける */
.sb-select-sm{
  width: 100%;
  max-width: 320px;   /* ←横長抑制の肝 */
}

/* 年齢 FROM〜TO 横並び */
.sb-age-range-inline{
  display: grid;
  grid-template-columns: minmax(0, 320px) 28px minmax(0, 320px);
  gap: 10px;
  align-items: center;
}
.sb-age-tilde{
  text-align: center;
  color: var(--sb-color-subtext);
}
@media (max-width: 480px){
  .sb-age-range-inline{
    grid-template-columns: 1fr;
  }
  .sb-age-tilde{ display:none; }
}

/* =========================
   チェック項目：密度UP + 4列(PC)/3列(スマホ)
========================= */

.sb-check-grid{
  /* 既存があっても上書きする */
  display: grid;
  gap: 6px 8px;
  margin-top: 6px;
}

/* PC: 4列 */
.sb-grid-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* スマホ: 3列（要望） */
@media (max-width: 768px){
  .sb-grid-4{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* さらに狭い端末は2列 */
@media (max-width: 420px){
  .sb-grid-4{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.sb-check-grid-compact .sb-check-item-compact{
  padding: 6px 8px;        /* ←詰める */
  line-height: 1.15;       /* ←行間狭く */
}
.sb-check-grid-compact .sb-check-item-compact span{
  font-size: 13px;         /* ←少し小さくして密度UP */
}

/* 子ジャンルは控えめに（階層感） */
.sb-check-child{
  opacity: .92;
}
/* ===== 検索フォーム：崩れ防止（page-member / page-battle共通で使える） ===== */
.sb-filter-row{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}
.sb-filter-col select,
.sb-filter-col input[type="text"]{
  width: 100%;
}
.sb-filter-col-wide{
  grid-column: span 3; /* PCではキーワードを横長に */
}

.sb-age-range{
  display: flex;
  align-items: center;
  gap: 8px;
}
.sb-age-tilde{
  flex: 0 0 auto;
  color: var(--sb-color-subtext);
}

@media (max-width: 768px){
  .sb-filter-row{
    grid-template-columns: 1fr;
  }
  .sb-filter-col-wide{
    grid-column: span 1;
  }
}

/* チェックボックスの詰め（行間が広すぎる対策） */
.sb-check-grid .sb-check-item{
  margin: 0;
  padding: 2px 0;
}
/* =========================
   page-member.php の崩れ修正（回り込み停止）
   影響範囲：#sb-recruit-list のみ
========================= */

#sb-recruit-list .sb-filter-form{
  display:block;            /* ← flex を殺す */
}

#sb-recruit-list .sb-filter-row{
  display:grid;
  grid-template-columns: repeat(6, minmax(0, 1fr)); /* PCは最大6枠 */
  gap: 12px;
  margin-bottom: 16px;
}

#sb-recruit-list .sb-filter-col{
  min-width: 0;
}

#sb-recruit-list .sb-filter-col select,
#sb-recruit-list .sb-filter-col input[type="text"]{
  width:100%;
  box-sizing:border-box;
}

#sb-recruit-list .sb-filter-col-wide{
  grid-column: span 2; /* キーワードだけ少し広く */
}

#sb-recruit-list .sb-filter-block{
  margin: 14px 0;
}

/* チェックグリッド：崩れ防止 */
#sb-recruit-list .sb-check-grid{
  display:grid;
  gap: 8px;
}

#sb-recruit-list .sb-check-grid-4{
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

/* ジャンル：親子を同じ枠内に見せる */
#sb-recruit-list .sb-genre-group{
  border: 1px solid var(--sb-color-border);
  border-radius: 10px;
  padding: 10px;
  background: #fff;
  margin-bottom: 10px;
}

#sb-recruit-list .sb-genre-parent-item{
  margin-bottom: 8px;
  font-weight: 600;
}

#sb-recruit-list .sb-genre-children{
  margin-top: 8px;
}

/* ボタンの回り込み防止 */
#sb-recruit-list .sb-filter-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 16px;
}

/* 年齢 FROM〜TO の横並び固定 */
#sb-recruit-list .sb-age-range{
  display:flex;
  align-items:center;
  gap: 8px;
}

#sb-recruit-list .sb-age-tilde{
  flex: 0 0 auto;
  opacity: .7;
}

/* =========================
   SP（スマホ）
========================= */
@media (max-width: 768px){
  #sb-recruit-list .sb-filter-row{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  #sb-recruit-list .sb-filter-col-wide{
    grid-column: 1 / -1; /* キーワードは全幅 */
  }

  #sb-recruit-list .sb-check-grid-4{
    grid-template-columns: repeat(3, minmax(0, 1fr)); /* スマホは3列 */
  }

  #sb-recruit-list .sb-filter-actions{
    flex-direction: column;
  }

  #sb-recruit-list .sb-filter-actions .sb-btn{
    width:100%;
    text-align:center;
  }
}
/* =========================
   page-member.php スマホ最適化（崩れ修正）
   影響範囲：#sb-recruit-list のみ
========================= */
@media (max-width: 768px){

  /* 1) 上段の検索条件：全部1行（1カラム）にする */
  #sb-recruit-list .sb-filter-row{
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  #sb-recruit-list .sb-filter-col-wide{
    grid-column: auto !important; /* 変なspanを解除 */
  }

  /* 年齢（FROM〜TO）は横並び維持。幅だけ破綻しないように */
  #sb-recruit-list .sb-age-range{
    display:flex;
    gap: 8px;
    align-items:center;
  }
  #sb-recruit-list .sb-age-range select{
    width: 100%;
    min-width: 0;
  }

  /* 2) チェックグリッド：3列を維持しつつ、中の文字が必ず見えるように */
  #sb-recruit-list .sb-check-grid-4{
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  /* “枠だけで文字が見えない”の対策：
     - label内が崩れている（display/align/overflow/line-height等）可能性が高いので
       スマホだけ安全な形にリセット */
  #sb-recruit-list .sb-check-item{
    display:flex !important;
    align-items:center !important;
    gap: 8px !important;

    /* ピル型 */
    border: 1px solid var(--sb-color-border, #d7dbe2) !important;
    border-radius: 12px !important;
    padding: 10px 10px !important;
    background: #fff !important;

    /* 文字が消える/はみ出す対策 */
    min-width: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
  }

  /* チェックボックスとテキストを確実に表示 */
  #sb-recruit-list .sb-check-item input[type="checkbox"]{
    flex: 0 0 auto !important;
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
  }

  #sb-recruit-list .sb-check-item span{
    display:block !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;

    /* “文字が入っていないように見える”対策（色・行高） */
    color: #111 !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* 3) こだわり条件だけは、指定どおり2列にする（スマホ） */
  #sb-recruit-list .sb-filter-block:last-of-type .sb-check-grid-4{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  /* ↑ last-of-type がズレる可能性があるので、確実にするなら
     HTML側で「こだわり条件ブロック」に class 追加してそこへ当てるのがベスト。
     例：<div class="sb-filter-block sb-block-condition"> にして
     .sb-block-condition .sb-check-grid-4 { repeat(2) } にする */

  /* 4) ボタンはスマホは縦並び・全幅 */
  #sb-recruit-list .sb-filter-actions{
    display:flex;
    flex-direction: column;
    gap: 10px;
  }
  #sb-recruit-list .sb-filter-actions .sb-btn{
    width:100%;
    text-align:center;
  }

  /* 5) ジャンル枠（親子）をスマホで詰める */
  #sb-recruit-list .sb-genre-group{
    padding: 10px !important;
  }
  #sb-recruit-list .sb-genre-parent-item{
    margin-bottom: 8px !important;
  }
}
@media (max-width:768px){
  #sb-member-edit .sb-cond-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .container{
    max-width:none;   /* スマホは全幅 */
    margin-left:-10px;margin-right:-10px;
  }
}
#sb-member-edit .sb-genre-parent-title{
  margin:0 0 8px;
  padding-bottom:8px;
}
#sb-member-edit .sb-genre-children{margin-top:6px;}
/* ===== SB Sidebar (Common Component) ===== */
.sb-sidebar{
  width: 100%;
}
.sb-sidebar__inner{
  position: sticky;
  top: 16px;
  display: grid;
  gap: 16px;
}

/* SPでは sticky を解除（回り込み時に自然に） */
@media (max-width: 900px){
  .sb-sidebar__inner{
    position: static;
    top: auto;
  }
}