/* LCHSP — Home page sections. Ported from the prototype (home.jsx). */

/* Shared dark-surface helpers */
.lchsp .surface-dark h2,
.lchsp .on-dark-text { color: var(--paper); }

/* ===== 1. HERO (full-bleed) ===== */
.lchsp .hero { position: relative; }
.lchsp .hero-media { position: absolute; inset: 0; border: none; border-radius: 0; }
.lchsp .hero-overlay { position: absolute; inset: 0; background: var(--hero-overlay); }
.lchsp .hero-inner {
  position: relative;
  min-height: clamp(560px, 80vh, 820px);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding-top: 80px; padding-bottom: 64px;
  color: var(--paper);
}
.lchsp .hero-title {
  font-size: clamp(42px, 6vw, 84px);
  color: var(--paper);
  font-weight: 300;
  margin: 20px 0 32px;
  max-width: 960px;
}
.lchsp .hero-title em { font-style: italic; }
.lchsp .hero-lead {
  font-size: 19px; line-height: 1.5; max-width: 620px;
  color: color-mix(in srgb, var(--paper) 88%, transparent);
  margin-bottom: 40px;
}
.lchsp .hero-ctas { gap: 12px; }
.lchsp .hero-btn-glass {
  background: color-mix(in srgb, var(--paper) 10%, transparent);
  color: var(--paper);
  border: 1px solid color-mix(in srgb, var(--paper) 35%, transparent);
  backdrop-filter: blur(8px);
}
.lchsp .hero-btn-glass:hover { background: color-mix(in srgb, var(--paper) 18%, transparent); }
.lchsp .hero-btn-outline {
  background: transparent; color: var(--paper);
  border: 1px solid color-mix(in srgb, var(--paper) 35%, transparent);
}
.lchsp .hero-btn-outline:hover { background: color-mix(in srgb, var(--paper) 10%, transparent); }
.lchsp .hero-corner {
  position: absolute; top: 24px; right: 40px;
  display: flex; gap: 16px; align-items: center;
  color: color-mix(in srgb, var(--paper) 70%, transparent);
  font-size: 10px; letter-spacing: 0.12em;
}
.lchsp .hero-corner .sep { opacity: 0.4; }
@media (max-width: 720px) {
  .lchsp .hero-corner { right: 20px; }
  .lchsp .hero-inner { padding-top: 64px; }
}

/* ===== 2. STATS ===== */
.lchsp .stats-section { padding: 72px 0; border-bottom: 1px solid var(--rule); background: var(--cream); }
.lchsp .stats-eyebrow { margin-bottom: 32px; }
.lchsp .stats-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.lchsp .stat { padding: 32px 32px 32px 32px; border-left: 1px solid var(--rule-strong); }
.lchsp .stat:first-child { border-left: none; padding-left: 0; }
.lchsp .stat-num {
  font-family: var(--serif); font-size: clamp(48px, 6vw, 76px);
  line-height: 1; letter-spacing: -0.03em; color: var(--teal); margin-bottom: 16px;
}
.lchsp .stat-label { font-size: 16px; max-width: 280px; margin-bottom: 12px; line-height: 1.35; }
@media (max-width: 960px) {
  .lchsp .stats-grid { grid-template-columns: 1fr; }
  .lchsp .stat { border-left: none; padding-left: 0; border-top: 1px solid var(--rule-strong); }
  .lchsp .stat:first-child { border-top: none; }
}

/* ===== 3. MISSION ===== */
.lchsp .mission-section { padding: 96px 0; }
.lchsp .mission-grid { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; align-items: start; }
.lchsp .mission-statement {
  font-family: var(--serif); font-size: clamp(24px, 2.4vw, 34px);
  line-height: 1.3; letter-spacing: -0.015em; color: var(--ink); margin-bottom: 28px;
}
.lchsp .mission-context { color: var(--ink-60); font-size: 17px; max-width: 640px; }
@media (max-width: 960px) { .lchsp .mission-grid { grid-template-columns: 1fr; gap: 24px; } }

/* ===== 4. IN MOTION ===== */
.lchsp .in-motion { padding: 96px 0; background: var(--cream); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.lchsp .motion-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.lchsp .motion-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 4px solid var(--c, var(--teal));
  border-radius: 10px; padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
}
.lchsp .motion-card-top { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.lchsp .motion-committee { color: var(--c, var(--teal)); }
.lchsp .motion-chip { background: color-mix(in srgb, var(--c, var(--teal)) 12%, transparent); color: var(--c, var(--teal)); }
.lchsp .motion-title { font-size: 24px; line-height: 1.2; }
.lchsp .motion-body { font-size: 15px; color: var(--ink-60); margin: 0; flex: 1; }
.lchsp .motion-more {
  align-self: flex-start; color: var(--c, var(--teal)); font-size: 14px;
  border-bottom: 1px solid var(--c, var(--teal)); text-decoration: none;
}
@media (max-width: 960px) { .lchsp .motion-grid { grid-template-columns: 1fr; } }

/* ===== 5. PRIMARY CTAS ===== */
.lchsp .primary-ctas { padding: 96px 0; background: var(--navy-deep); color: var(--paper); }
.lchsp .cta-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.lchsp .cta-card {
  display: flex; flex-direction: column; gap: 16px; min-height: 260px; padding: 36px;
  border-radius: 14px; text-decoration: none;
  background: color-mix(in srgb, var(--paper) 5%, transparent);
  border: 1px solid color-mix(in srgb, var(--paper) 18%, transparent);
  color: var(--paper); transition: all .2s ease;
}
.lchsp .cta-card:hover { background: var(--teal); border-color: var(--teal); color: var(--paper); }
.lchsp .cta-num { color: color-mix(in srgb, var(--paper) 80%, transparent); } /* AA: light on dark card */
.lchsp .cta-title { font-family: var(--serif); font-size: 32px; }
.lchsp .cta-body { font-size: 15px; line-height: 1.5; opacity: 0.8; flex: 1; }
.lchsp .cta-continue { font-size: 14px; opacity: 0.9; display: flex; gap: 8px; align-items: center; }
@media (max-width: 960px) { .lchsp .cta-grid { grid-template-columns: 1fr; } }

/* ===== 6. UPCOMING ===== */
.lchsp .upcoming { padding: 96px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.lchsp .featured-event { display: grid; grid-template-columns: 1fr 1.2fr; gap: 48px; padding: 32px 0 48px; border-bottom: 1px solid var(--rule); }
.lchsp .featured-detail { display: flex; flex-direction: column; justify-content: space-between; gap: 24px; }
.lchsp .featured-chip { margin-bottom: 20px; }
.lchsp .featured-title { font-size: clamp(28px, 3vw, 44px); margin-bottom: 20px; }
.lchsp .featured-desc { font-size: 17px; color: var(--ink-60); max-width: 520px; }
.lchsp .featured-save { margin-top: 16px; color: var(--teal); }
.lchsp .featured-actions { gap: 10px; }
.lchsp .featured-date { background: var(--teal); color: var(--paper); padding: 40px; border-radius: 14px; display: flex; flex-direction: column; gap: 20px; }
.lchsp .featured-date-label { color: color-mix(in srgb, var(--paper) 88%, transparent); } /* AA: light on teal */
.lchsp .featured-date-big { font-family: var(--serif); font-size: clamp(72px, 10vw, 140px); line-height: 0.85; letter-spacing: -0.04em; }
.lchsp .featured-date-meta { display: flex; flex-direction: column; gap: 6px; margin-top: auto; }
.lchsp .featured-date-meta div { font-size: 14px; opacity: 0.9; }
.lchsp .event-list { display: flex; flex-direction: column; }
.lchsp .event-row { display: grid; grid-template-columns: 100px 1fr 200px 140px 100px; align-items: center; gap: 24px; padding: 22px 0; border-top: 1px solid var(--rule); }
.lchsp .event-row:first-child { border-top: none; }
.lchsp .event-date { font-family: var(--serif); font-size: 22px; letter-spacing: -0.01em; }
.lchsp .event-day { display: block; font-size: 10px; margin-top: 2px; }
.lchsp .event-title { font-size: 17px; font-weight: 500; }
.lchsp .event-place { color: var(--ink-60); font-size: 14px; }
.lchsp .event-link { text-align: right; font-size: 14px; }
@media (max-width: 960px) {
  .lchsp .featured-event { grid-template-columns: 1fr; }
  .lchsp .event-row { grid-template-columns: 70px 1fr auto; gap: 12px 16px; }
  .lchsp .event-place { display: none; }
  .lchsp .event-link { display: none; }
}

/* ===== 7. PARTNERS ===== */
.lchsp .partners { padding: 96px 0; }
.lchsp .partners-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 32px; flex-wrap: wrap; gap: 16px; }
.lchsp .partners-asof { color: var(--ink-60); } /* AA: ink-40 fell to 4.31:1 */
.lchsp .backbone-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 72px; }
.lchsp .backbone-card { border: 1px solid var(--rule); border-radius: var(--r-lg); padding: 28px; display: flex; flex-direction: column; gap: 20px; min-height: 180px; }
.lchsp .backbone-card.is-pending { opacity: 0.85; }
.lchsp .backbone-abbr { width: 40px; height: 40px; border-radius: 8px; background: var(--cream-deep); display: grid; place-items: center; font-family: var(--serif); font-size: 18px; color: var(--teal-deep); } /* AA: teal-deep survives the 0.85 pending dim */
.lchsp .backbone-name { font-size: 15px; font-weight: 500; line-height: 1.3; flex: 1; }
.lchsp .backbone-note { color: var(--ink-60); }
.lchsp .backbone-note.is-pending { color: var(--moss-deep); } /* AA: moss-deep survives the 0.85 dim */
.lchsp .members-label { margin-bottom: 24px; }
.lchsp .members-grid { display: flex; flex-wrap: wrap; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.lchsp .member { flex: 1 1 25%; min-width: 200px; padding: 28px 24px; border-right: 1px solid var(--rule); font-family: var(--serif); font-size: 20px; letter-spacing: -0.01em; color: var(--ink-60); }
.lchsp .member:nth-child(4n) { border-right: none; }
.lchsp .member:nth-child(n+5) { border-top: 1px solid var(--rule); }
.lchsp .members-more { margin-top: 24px; text-align: right; }
@media (max-width: 960px) {
  .lchsp .backbone-grid { grid-template-columns: 1fr 1fr; }
  .lchsp .member { flex-basis: 50%; }
  .lchsp .member:nth-child(4n) { border-right: 1px solid var(--rule); }
  .lchsp .member:nth-child(2n) { border-right: none; }
}
@media (max-width: 560px) {
  .lchsp .backbone-grid { grid-template-columns: 1fr; }
  .lchsp .member { flex-basis: 100%; border-right: none; }
}

/* ===== 8. NEWSLETTER ===== */
.lchsp .newsletter { padding: 96px 0; background: var(--teal); color: var(--paper); }
.lchsp .newsletter-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
.lchsp .newsletter-copy { font-size: 17px; line-height: 1.5; opacity: 0.9; max-width: 440px; margin-top: 16px; }
.lchsp .newsletter-form { display: flex; flex-direction: column; gap: 12px; }
.lchsp .newsletter-emaillabel { color: color-mix(in srgb, var(--paper) 88%, transparent); }
.lchsp .newsletter-row { display: flex; gap: 10px; flex-wrap: wrap; }
.lchsp .newsletter-row input {
  flex: 1; min-width: 220px; padding: 16px 20px;
  background: color-mix(in srgb, var(--paper) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--paper) 30%, transparent);
  border-radius: var(--r-pill); color: var(--paper); font-size: 15px; font-family: inherit; outline: none;
}
.lchsp .newsletter-row input::placeholder { color: color-mix(in srgb, var(--paper) 60%, transparent); }
.lchsp .newsletter-btn { background: var(--paper); color: var(--teal-deep); }
.lchsp .newsletter-btn:hover { background: color-mix(in srgb, var(--paper) 88%, transparent); }
.lchsp .newsletter-fine { font-size: 12px; opacity: 0.85; margin-top: 4px; } /* AA: 0.7 fell to 4.31:1 */
@media (max-width: 960px) { .lchsp .newsletter-grid { grid-template-columns: 1fr; gap: 32px; } }
