/* ===== Sakura Members (clean + sort/group split) ===== */

/* --- wrapper --- */
.sakura-members{
  margin:16px 0;
}

/* --- controls --- */
.sakura-members-controls{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:0 0 12px;
}

/* 並び替え + 分類（横並び） */
.sakura-members-sortwrap{
  display:flex;
  align-items:center;
  gap:10px;              /* 既存8pxより少し余裕 */
  flex-wrap:wrap;
}

/* 「並び替え：select」「分類：select」を1つの塊として扱う */
.sakura-members-sortwrap .sm-ctrl{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

/* label */
.sakura-members-sortlabel{
  font-weight:700;
  opacity:.8;
  font-size:13px;
}

/* select（並び替え/分類 共通見た目） */
.sakura-members-sortselect,
.sakura-members-groupselect{
  border:1px solid rgba(0,0,0,.14);
  border-radius:10px;
  padding:8px 10px;
  font-size:13px;
  background:#fff;
}

/* 表示項目チェック */
.sakura-members-fieldsui{
  display:flex;
  flex-wrap:wrap;
  gap:8px 7px;
  align-items:center;
  font-size:13px;
}

.sakura-members-fieldslabel{
  font-weight:700;
  opacity:.8;
}

.sakura-members-fieldsui label{
  display:inline-flex;
  gap:6px;
  align-items:center;
  white-space:nowrap;
}

/* --- group heading (groupby用) --- */
.sakura-members-heading{
  margin:16px 0 10px;
  font-size:16px;
  padding-left:10px;
  border-left:4px solid rgba(0,0,0,.25);
}

/* --- grid --- */
.sakura-members-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;
}

@media (min-width:768px){
  .sakura-members-grid{
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }
}

/* --- card --- */
.sakura-member-card{
  border:1px solid rgba(0,0,0,.12);
  border-radius:14px;
  overflow:hidden;
  background:#fff;
}

/* --- photo --- */
.sakura-member-photo{
  position:relative;            /* バッジ/SNSの基準 */
  width:100%;
  aspect-ratio:7 / 10;          /* 縦長 */
  background:rgba(0,0,0,.04);
  overflow:hidden;
}

.sakura-member-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.sakura-member-noimg{
  width:100%;
  height:100%;
}

/* term badge (left-top overlay) */
.sakura-member-photo .sm-term-badge{
  position:absolute;
  top:6px;
  left:6px;
  z-index:5;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:5px 7px;
  border-radius:10px;

  background:rgba(0,0,0,.62);
  color:#fff;

  font-size:11px;
  line-height:1;
  font-weight:700;
  letter-spacing:.02em;

  border:0;
  text-decoration:none;
  box-shadow:none;
  opacity:1;
}

/* SNS overlay (left-bottom on photo) */
.sakura-member-photo .sm-sns{
  position:absolute;
  left:6px;
  bottom:6px;
  z-index:6;

  display:flex;
  align-items:center;
  gap:8px;

  /* アイコンのマージン/パディングは0、背景だけ残す */
  margin:0;
  padding:5px 6px;
  border-radius:10px;
  background:rgba(255,255,255,.45);
}

.sakura-member-photo .sm-sns-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  margin:0;
  padding:0;
  line-height:0;
}

.sakura-member-photo .sm-sns-icon{
  width:18px;
  height:18px;
  display:block;
  margin:0;
  padding:0;
}

/* --- body --- */
.sakura-member-body{
  padding:10px 10px 12px;
}

/* kana */
.sakura-member-kana{
  font-size:9px;
  line-height:1;
  opacity:.75;
  margin:0;
}

/* name */
.sakura-member-name{
  font-size:14px;
  font-weight:700;
  margin:0 0 6px;
  line-height:1.1;
}

/* profile meta (compact) */
.sakura-member-meta{
  display:flex;
  flex-wrap:wrap;
  gap:4px 8px;
  font-size:12px;
  line-height:1.2;
  opacity:.9;
}

.sm-meta{
  display:inline-flex;
  white-space:nowrap;
}

/* buttons */
.sakura-members-phototoggle,
.sakura-members-gradtoggle{
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  border-radius:10px;
  padding:8px 10px;
  font-size:13px;
  line-height:1;
}

/* Toggle buttons row (卒業 + 写真切替) */
.sakura-members-toggles{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}

/* 卒業ボタン：文言が変わっても幅を固定 */
.sakura-members-gradtoggle{
  width:150px;
  text-align:center;
  white-space:nowrap;
}

/* Group filter UI */
.sakura-members-groupsui{
  display:flex;
  flex-wrap:wrap;
  gap:8px 7px;
  align-items:center;
  font-size:13px;
}

.sakura-members-groupslabel{
  font-weight:700;
  opacity:.8;
}

.sakura-members-groupsui label{
  display:inline-flex;
  gap:6px;
  align-items:center;
  white-space:nowrap;
}
