/* IPR — Team roster page
   Reuses tokens, nav, cursor, grain and vignette from ../css/main.css.
   This file only adds the roster-specific layout. */

/* Static undercurrent backdrop — a calm echo of the homepage WebGL field,
   without the cost of running the shader on a sub-page. */
.team-bg {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 50% at 50% 0%, rgba(90, 180, 205, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse 80% 60% at 50% 120%, rgba(35, 51, 31, 0.45) 0%, transparent 60%),
    var(--onyx-deep);
}

/* Active nav item */
.nav__links a[aria-current="page"] { color: var(--snow); }

/* ---------- Hero ---------- */
.team-hero {
  padding: clamp(8rem, 22vh, 13rem) var(--pad) clamp(3rem, 8vh, 5rem);
  max-width: 1100px;
}
.team-hero__title {
  font-size: clamp(3rem, 11vw, 9rem);
  font-weight: 800; letter-spacing: -0.035em; line-height: 0.93;
  text-transform: uppercase;
  margin: 0.4rem 0 0;
}
.team-hero__sub {
  margin-top: clamp(1.5rem, 4vh, 2.5rem);
  font-size: clamp(1rem, 1.6vw, 1.35rem);
  line-height: 1.55; color: var(--snow-40);
  max-width: 44ch;
}

/* ---------- Roster grid ---------- */
.roster {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(1.75rem, 3.5vw, 3.5rem);
  padding: clamp(1rem, 3vh, 2rem) var(--pad) clamp(5rem, 12vh, 8rem);
}
.member {
  display: block; text-decoration: none; color: inherit;
  border-top: 1px solid var(--snow-12);
  padding-top: 1.25rem;
  position: relative;
}
.member::before {
  content: ""; position: absolute; top: -1px; left: 0;
  width: 0%; height: 1px; background: var(--iron);
  transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}
.member:hover::before { width: 100%; }

.member__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  max-width: 210px;          /* modest portrait, not a full-bleed billboard */
  overflow: hidden;
  background: var(--onyx);
  border-radius: 2px;
}
.member__photo img {
  width: 100%; height: 100%; object-fit: cover;
  /* Calm surface by default; sunlight reveals the true color on hover. */
  filter: grayscale(1) contrast(1.05) brightness(0.85);
  transform: scale(1.02);
  transition: filter 0.6s ease, transform 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}
.member:hover .member__photo img {
  filter: grayscale(0) contrast(1) brightness(1);
  transform: scale(1.06);
}

.member__role {
  display: block;
  margin-top: 1.25rem;
  font-size: 0.72rem; font-weight: 600;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--iron);
}
.member__name {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 700; letter-spacing: -0.02em; line-height: 1.05;
  margin: 0.7rem 0 0.5rem;
}
.member__loc {
  font-size: 0.85rem; letter-spacing: 0.04em;
  color: var(--snow-40);
}
.member__line {
  margin: 1rem 0 1.5rem;
  font-size: 0.95rem; line-height: 1.6;
  color: var(--snow);
  max-width: 34ch;
}
.member__cta {
  display: inline-flex; align-items: center; gap: 0.4rem;
  font-size: 0.8rem; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--snow-40);
  transition: color 0.25s ease, gap 0.25s ease;
}
.member:hover .member__cta { color: var(--snow); gap: 0.7rem; }

/* ---------- Closing CTA ---------- */
.team-foot {
  padding: clamp(4rem, 10vh, 7rem) var(--pad) clamp(1.5rem, 4vh, 3rem);
  border-top: 1px solid var(--snow-12);
}
.team-foot__title {
  font-size: clamp(2.2rem, 7vw, 5.5rem);
  font-weight: 800; letter-spacing: -0.035em; line-height: 0.95;
  text-transform: uppercase;
}
.team-foot__cta {
  display: inline-block;
  margin-top: clamp(1.75rem, 5vh, 3rem);
  color: var(--snow); text-decoration: none;
  font-size: clamp(1rem, 2.2vw, 1.7rem); font-weight: 600;
}
.team-foot__cta em {
  display: block; height: 2px; margin-top: 0.35rem;
  background: var(--chartreuse);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.team-foot__cta:hover em { transform: scaleX(1); }
.team-foot__base {
  display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap;
  margin-top: clamp(4rem, 10vh, 7rem);
  padding-top: 1.5rem;
  border-top: 1px solid var(--snow-12);
  font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--snow-40);
}

/* ---------- Mobile ---------- */
@media (max-width: 860px) {
  .roster { grid-template-columns: 1fr; gap: 2.5rem; }
  .member__photo { aspect-ratio: 4 / 5; max-width: 170px; }
}
@media (max-width: 760px) {
  .nav__links a:not(.nav__cta) { display: none; }
}
