/* ===== Members page (scoped) ===== */
.members-page .members-hero{
  position: relative; isolation: isolate; overflow: hidden;
  background:
    radial-gradient(1200px 480px at 20% -10%, rgba(41,179,107,.18), transparent 60%),
    linear-gradient(135deg, #ffffff 0%, #effaf4 40%, #e7f7ef 100%);
  border-bottom: 1px solid var(--line);
}
.members-page .members-hero .wrap{
  padding-block: clamp(44px, 7vw, 84px);
}
.members-page .members-hero .hero-content{
  color: white; text-shadow: 0 2px 8px rgba(0,0,0,0.6);
  max-width: 720px; margin-left: clamp(5%, 8vw, 120px); text-align: left;
}
.members-page .members-hero .hero-copy h1{
  margin: 0 0 6px; font-size: clamp(32px, 6vw, 48px); letter-spacing: .01em;
}
.members-page .members-hero .hero-copy .subtitle{
  display:inline-block; padding:6px 12px; border-radius:999px; font-weight:700; letter-spacing:.02em;
  color:#0c5132;
  background: color-mix(in oklab, var(--green) 8%, #ffffff 92%);
  border:1px solid color-mix(in oklab, var(--green) 10%, #dff3e9 90%);
}
.members-page .members-hero-bg{
  position:absolute; inset:0; z-index:1; backdrop-filter:saturate(160%) blur(2px); pointer-events:none;
}
.members-page .members-hero .wrap{ position:relative; z-index:2; }

/* Intro（中央寄せ・幅を絞る） */
.members-page .members-intro .wrap.narrow{ width:min(720px, 90vw); }
.members-page .members-intro .center{ text-align:center; color:#1f2937; line-height:1.95; }

/* Grid（ビジュアル重視：広めのgap & 中央寄せ） */
.members-page .members-main{ background: linear-gradient(135deg, #ffffff 0%, #effaf4 40%, #e7f7ef 100%); }
.members-page .members-grid{
  list-style:none; margin:0; padding: 10px 0 50px;
  display:grid; gap:20px;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 1080px){ .members-page .members-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 760px){ .members-page .members-grid{ grid-template-columns: 1fr; } }

/* Card */
.members-page .member-card{
  background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  overflow:hidden; box-shadow: var(--shadow);
  display:grid; grid-template-rows: auto 1fr auto;
}
.members-page .member-media{ aspect-ratio: 16 / 9; background:#eaf6f0; overflow:hidden; }
.members-page .member-media img{ width:100%; height:100%; object-fit:cover; display:block; }

.members-page .member-body{ padding:14px; display:grid; gap:8px; }
.members-page .member-name{ margin:0; font-size:18px; font-weight:800; }
.members-page .member-role{ margin:0; font-size:14px; color:#6b7f78; }
.members-page .member-bio{ margin:4px 0 0; color:#1f2937; line-height:1.8; }

/* Works & SNS */
.members-page .member-foot{ border-top:1px solid var(--line); padding:10px 14px; display:grid; gap:8px; }
.members-page .work{ display:flex; align-items:center; justify-content:space-between; gap:8px; }
.members-page .work a{ color:#0c5132; font-weight:800; text-decoration:none; }
.members-page .work-type{
  font-size:12px; color:#6b7f78; background:#f1f5f3; padding:2px 8px; border-radius:999px; border:1px solid #e2ebe5;
}
.members-page .sns{
  display:flex; flex-wrap:wrap; gap:8px;
}
.members-page .sns a{
  display:inline-flex; align-items:center; gap:6px;
  color:#0c5132; text-decoration:none; font-weight:800;
  background:#eefaf3; border:1px solid #d6f3e4; border-radius:999px; padding:4px 10px;
}

/* Fade-in（保険） */
.members-page .fadein{ opacity:0; transform: translateY(10px); }
.members-page .is-in{ opacity:1; transform:none; transition: opacity .6s ease, transform .6s ease; }

/* A11y: motion reduce */
@media (prefers-reduced-motion: reduce){
  .members-page *{
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}
