/* =========================
   Members v2 (独立CSS)
   ========================= */

.members2 {
 padding-top: 60px;
}
.members2__title {
 font-size: clamp(30px, 3vw, 52px);
 font-weight: 600;
 letter-spacing: 0.02em;
 margin: 0;
 margin-inline: 60px;
 margin-bottom: 60px;
}
.members2__header {
 display: flex;
 align-items: flex-end;
 justify-content: space-between;
 gap: 18px;
 margin-inline: 60px;
 flex-wrap: wrap;
}
.members2__filters {
 display: flex;
 gap: 10px;
 align-items: center;
 flex-wrap: wrap;
}
.members2__filter {
 display: grid;
 place-items: center;
 gap: 0px;
 width: 120px;
 height: 110px;
 border: 1px solid rgba(0, 0, 0, 0.12);
 background: #f3f3f3;
 padding: 5px;
 cursor: pointer;
 transition:
  transform 0.12s ease,
  background 0.12s ease,
  border-color 0.12s ease;
}
.members2__filter.is-active {
 background: #fbf151;
 border-color: rgba(0, 0, 0, 0.18);
}
.members2__filterIcon img {
 width: 60px;
 height: 60px;
 object-fit: contain;
 display: block;
 filter: grayscale(1);
 opacity: 0.85;
}
.members2__filter.is-active .members2__filterIcon img {
 filter: none;
 opacity: 1;
}
.members2__filterText {
 font-size: 13px;
 font-weight: 600;
 text-transform: uppercase;
 letter-spacing: 0;
 text-align: center;
 line-height: 1.1;
 display: flex;
 align-items: flex-start;
 height: 40px;
}

/* band */
.members2__band {
 margin-top: 24px;
 margin-inline: 60px;
 height: 56px;
 background: #b7b7b7;
 display: flex;
 align-items: center;
 padding: 0 16px;
 color: #fff;
 font-size: 34px;
 font-weight: 200;
 letter-spacing: 0.08em;
 text-transform: uppercase;
}

/* grid */
.members2__grid {
 margin-top: 26px;
 margin-inline: 60px;
 display: grid;
 grid-template-columns: repeat(6, minmax(0, 1fr));
 gap: 14px;
}

/* card */
.mcard {
 overflow: hidden;
}
.mcard.is-hidden {
 display: none;
}
.mcard__photoLink {
 position: relative;
 width: 100%;
 aspect-ratio: 4 / 5;
 overflow: hidden;
 background: #f5f5f5;
 cursor: pointer;
 display: block;
 text-decoration: none;
 color: inherit;
}
.mcard__photo {
 width: 100%;
 aspect-ratio: 4 / 5;
 height: 100%;
 object-fit: cover;
 display: block;
 position: relative;
 transition: all 0.4s;
}

/* purpose overlay */
.purpose-overlay {
 position: absolute;
 inset: 0;
 display: grid;
 place-items: center;
 background: rgba(0, 0, 0, 0.55);
 opacity: 0;
 transform: translateY(6px);
 transition:
  opacity 0.15s ease,
  transform 0.15s ease;
 pointer-events: none;
}

.purpose-overlay__inner {
 width: calc(100% - 28px);
 max-height: calc(100% - 28px);
 overflow: hidden;
 text-align: left;
 display: flex;
 flex-direction: column;
}
.purpose-overlay__label {
 font-size: 12px;
 font-weight: 600;
 letter-spacing: 0.02em;
 color: rgba(255, 255, 255, 0.7);
 margin-bottom: 10px;
 display: flex;
 margin-inline: auto;
 border: 1px solid rgba(255, 255, 255, 0.6);
 padding: 0.5em;
}

.purpose-overlay__text {
 font-size: 13px; /* ← Purpose文字は小さめ */
 line-height: 1.5;
 color: #fff;
 display: -webkit-box;
 -webkit-line-clamp: 12; /* 長文でも暴れない */
 -webkit-box-orient: vertical;
 overflow: hidden;
}

/* meta */
.mcard__meta {
 padding-block: 10px 14px;
 display: grid;
 gap: 0;
}
.mcard__dept {
 font-size: 13px;
 font-weight: 400;
 letter-spacing: 0.06em;
 text-transform: uppercase;
 color: rgba(0, 0, 0, 0.55);
}
.mcard__name {
 font-size: 20px;
 font-weight: 700;
 color: #222;
}

/* -------------------------
   Filter: ALL だけ特別扱い
-------------------------- */
.members2__filter.is-all {
    /* grid をやめて中央寄せの flex にする */
    display: flex;
    align-items: center;
    justify-content: flex-start;
    /* iconが無いので余白・段差の原因になる gap を潰す */
    gap: 0;
    padding: 0;
    /* ボタンのデフォルトoutlineが見えてる場合があるので整える */
    outline: none;
}

/* ALL のテキストを枠の中心に綺麗に */
.members2__filter.is-all .members2__filterText {
 display: flex;
 align-items: center;
 justify-content: flex-start;
 height: 100%;
 width: 100%;
 margin: 0;
 padding: 20px 20px;
}

/* フォーカス時の見た目（任意：デフォルトの枠線を消してカスタムに） */
.members2__filter:focus-visible {
 outline: 2px solid rgba(0, 0, 0, 0.25);
 outline-offset: 2px;
}
.members2__filter {
 appearance: none;
 -webkit-appearance: none;
 border: 1px solid rgba(0, 0, 0, 0.12);
 background: #f3f3f3;
}
.members2__filterText {
 color: #000000;
 font-size: 13px;
 letter-spacing: 0;
}

@media (min-width: 769px) {
 .members2__filter:hover {
  background: #b7b7b7;
 }
 .mcard__photoLink:hover .purpose-overlay,
 .mcard__photoLink:focus-visible .purpose-overlay {
  opacity: 1;
  transform: translateY(0);
 }
 .mcard__photoLink:hover img.mcard__photo {
  transform: scale(1.1);
 }
}

@media (max-width: 1600px) {
 .members2__grid {
  grid-template-columns: repeat(5, minmax(0, 1fr));
 }
}

@media (max-width: 1280px) {
 .members2__grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
 }
}

@media (max-width: 900px) {
 .members2__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
 }
}

@media (max-width: 768px) {
 .members2__title {
  margin-inline: 30px;
  margin-bottom: 30px;
 }
 .members2__header {
  gap: 18px;
  margin-inline: 30px;
 }
 .members2__filters {
  gap: 5px;
  flex-wrap: nowrap;
 }
 .members2__filter {
  width: 114px;
 }
 .members2__band {
  margin-inline: 30px;
  font-size: 28px;
 }
 .members2__grid {
  margin-inline: 30px;
 }
}

@media (max-width: 600px) {
 .members2 {
  padding-top: 30px;
 }
 .members2__title {
  margin-inline: 20px;
  margin-bottom: 30px;
 }
 .members2__header {
  gap: 18px;
  margin-inline: 20px;
 }
 .members2__filters {
  gap: 5px;
  flex-wrap: wrap;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
 }
 .members2__band {
  margin-inline: 20px;
  font-size: 20px;
  height: auto;
  padding: 6px 10px;
 }
 .members2__grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 16px;
  margin-inline: 20px;
 }
 .members2__filter {
  width: auto;
  height: 100px;
 }
 .members2__filterText {
  color: #000000;
  font-size: 12px;
  letter-spacing: 0;
  height: 30px;
 }
 .mcard__meta {
  padding-block: 6px;
 }
 .mcard__name {
  font-size: 1rem;
 }
 .mcard__dept {
  font-size: 12px;
  letter-spacing: 0.02em;
 }
}
