/* =============================================================
   ALPHA LAMBDA — MEMBERS PAGE STYLES  v1.2
   Mirrors about-page.css conventions exactly.
   ============================================================= */

/* ── Layout ─────────────────────────────────────────────────── */
.members-container {
  max-width: var(--max-width, 1200px);
  margin: 0 auto;
  padding: 0 40px;
}

.members-section {
  padding: 5rem 0;
}

/* ── Hero + Dues split ───────────────────────────────────────── */
.members-hero-dues-split {
  background: var(--grey-light);
  border-bottom: 1px solid var(--kream-dark);
  padding: 2rem 2rem 2rem;
  min-height: 55vh;
  align-content: center;
}

.members-hero-dues-split .members-container {
  display: flex;
  align-items: center;  /* was: center — now tops align */
  gap: 0;
}

/* Left: hero copy */
.split-hero {
  flex: 1 1 0;
  padding-right: 3.5rem;
}

/* Vertical krimson rule */
.split-divider {
  width: 2px;
  align-self: stretch;
  background: var(--krimson);
  flex-shrink: 0;
  opacity: 0.25;
}

/* Right: dues CTA */
.split-dues {
  flex: 1 1 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;                   /* was: 1rem — now matches hero spacing flow */
}

.split-dues .label-text {
  color: var(--grey-dark);
  opacity: 0.6;
  display: block;
  margin-bottom: 0.4rem;    /* mirrors hero label→title gap */
}

.split-dues-heading {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4vw, 3.6rem);  /* matches .members-hero-title */
  font-weight: 700;
  color: var(--krimson-dark);
  line-height: 1.05;
  letter-spacing: -0.01em;
  margin: 0 0 1rem;
}

.split-dues-body {
  font-family: var(--font-body);
  font-size: 1.05rem;       /* matches .members-hero-sub */
  line-height: 1.7;
  color: var(--grey-dark);
  margin: 0 0 2rem;         /* pushes button down like hero sub → content gap */
  max-width: 600px;
  text-align: center;
}

.split-dues .dues-cta-actions {
  margin-top: 0;
}

/* ── Hero (standalone — kept for other templates) ────────────── */
.members-hero {
  background: var(--grey-light);
  border-bottom: 1px solid var(--kream-dark);
  padding: 5rem 0 4rem;
  min-height: 68vh;
}

.members-hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 4vw, 3.6rem) !important;
  font-weight: 700;
  color: var(--krimson-dark);
  line-height: 1.05;
  margin: 0.4rem 0 1rem;
  letter-spacing: -0.01em;
}

.members-hero-sub {
  font-family: var(--font-body);
  font-size: 1.05rem;
  color: var(--grey-dark);
  max-width: 640px;
  line-height: 1.7;
  font-style: italic;
  margin: 0;
}

/* ── Section headings ────────────────────────────────────────── */
#members-page h2 {
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  color: var(--krimson-dark);
  margin: 0 0 1rem;
}

#members-page h3 {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--krimson-dark);
  margin: 0 0 0.3rem;
}

#members-page p {
  font-family: var(--font-body);
  font-size: 1.2rem;
  line-height: 1.8;
  color: var(--grey-dark);
  margin: 0 0 1rem;
}

#members-page p.dues-body-text {
  color: var(--grey-light);
}

#members-page p:last-child { margin-bottom: 0; }

.members-section-intro {
  max-width: 680px;
  margin-bottom: 2.5rem !important;
}

/* ── Board section — light bg, reuses about-page team grid ───── */
.members-board-section {
  background: var(--kream);
}

/* about-team-grid, about-member, about-avatar-* all come from
   about-page.css which is also enqueued on this template. */

/* ── Roster section ──────────────────────────────────────────── */
.members-roster-section {
  background: var(--grey-light);
}

/* Filter tab bar */
.roster-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 2.5rem;
}

.roster-filter-btn {
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 8px 18px;
  background: var(--kream);
  color: var(--krimson);
  border: 1px solid var(--krimson);
  border-radius: 999px;
  cursor: pointer;
  transition: background 0.18s, color 0.18s, transform 0.18s;
}

.roster-filter-btn:hover,
.roster-filter-btn.active {
  background: var(--krimson);
  color: var(--kream);
  transform: translateY(-1px);
}

/* Each year group */
.roster-line-group {
  margin-bottom: 2rem;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--kream-darker);
}

.roster-line-header {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0.85rem 1.5rem;
  background: var(--krimson);
}

.roster-line-label {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  color: var(--kream);
}

.roster-line-count {
  font-family: var(--font-ui);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(241,241,231,0.4);
  margin-left: auto;
}

/* Name list — clean two-column grid */
.roster-name-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  background: var(--kream);
}

.roster-name-item {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding: 0.65rem 1.25rem;
  border-bottom: 1px solid var(--kream-dark);
  border-right: 1px solid var(--kream-dark);
  transition: background 0.15s;
}

.roster-name-item:hover {
  background: var(--grey-light);
}

.roster-name-num {
  font-family: var(--font-ui);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: var(--krimson);
  opacity: 0.55;
  flex-shrink: 0;
  min-width: 18px;
}

.roster-name-text {
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--krimson-dark);
}

/* Empty state */
.members-empty-state {
  background: var(--kream);
  border: 2px dashed var(--kream-darker);
  border-radius: 8px;
  padding: 3rem;
  text-align: center;
}

.members-empty-state p {
  color: var(--grey-mid);
  font-family: var(--font-ui);
  font-size: 0.85rem;
  letter-spacing: 0.04em;
}

/* ── Dues section (standalone — kept for other templates) ─────── */
.members-dues-section {
  background: var(--krimson-dark);
  position: relative;
  overflow: hidden;
}

.dues-cta-box {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 2rem;
}

.dues-cta-text .label-text {
  color: rgba(241,241,231,0.45);
}

.dues-cta-text h2 {
  color: var(--kream) !important;
  margin-bottom: 0.6rem;
}

.dues-cta-text p {
  color: rgba(241,241,231,1);
  max-width: 520px;
  margin: 0 auto;
}

.dues-cta-actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  flex-shrink: 0;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.members-btn-primary {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 14px 34px;
  background: var(--krimson);
  color: var(--kream) !important;
  text-decoration: none;
  border: 2px solid var(--krimson);
  transition: background 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
}

.members-btn-primary:hover {
  background: var(--krimson-dark);
  border-color: var(--krimson-dark);
  color: var(--kream) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(122,0,0,0.3);
}

.members-btn-outline {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 14px 34px;
  background: transparent;
  color: var(--krimson) !important;
  border: 2px solid var(--krimson);
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s, box-shadow 0.2s;
  cursor: pointer;
}

.members-btn-outline:hover {
  background: var(--krimson);
  color: var(--kream) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(122,0,0,0.3);
}

/* ── Responsive ─────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .about-team-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 860px) {
  .members-hero { padding: 4rem 0 3rem; }

  .members-hero-dues-split .members-container {
    flex-direction: column;
    gap: 2.5rem;
  }

  .split-hero    { padding-right: 0; }
  .split-dues    { padding-left: 0; }

  .split-divider {
    width: 100%;
    height: 2px;
    align-self: auto;
  }

  .dues-cta-box { flex-direction: column; align-items: flex-start; gap: 2rem; }
}

@media (max-width: 600px) {
  .members-container { padding: 0 24px; }
  .members-section   { padding: 3.5rem 0; }

  .about-team-grid        { grid-template-columns: repeat(2, 1fr); }
  .roster-name-list       { grid-template-columns: 1fr; }
  .dues-cta-actions       { flex-direction: column; }
}