/* LCHSP — Events & Calendar. Ported from events.jsx; live calendar = Google iframe. */

.lchsp .events-hero { padding: 64px 0 40px; border-bottom: 1px solid var(--rule); }
.lchsp .events-hero-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: end; }
.lchsp .events-h1 { margin-top: 24px; max-width: 980px; }
.lchsp .events-h1 em { font-style: italic; color: var(--teal); }
.lchsp .events-lead { font-size: 19px; color: var(--ink-60); max-width: 680px; margin-top: 24px; }
.lchsp .events-hero-actions { margin-top: 28px; gap: 10px; }
.lchsp .events-livecard { border: 1px solid var(--rule); border-radius: 14px; padding: 24px; background: var(--cream); display: flex; flex-direction: column; gap: 10px; }
.lchsp .events-live-label { color: var(--moss-deep); }
.lchsp .events-live-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--moss); margin-right: 8px; }
.lchsp .events-live-title { font-family: var(--serif); font-size: 18px; line-height: 1.3; }
.lchsp .events-live-sub { font-size: 13px; color: var(--ink-60); }

/* Featured */
.lchsp .events-featured-section { padding: 72px 0; }
.lchsp .events-featured-eyebrow { margin-bottom: 24px; }
.lchsp .events-featured { border: 1px solid var(--ink); border-radius: 14px; overflow: hidden; display: grid; grid-template-columns: 440px 1fr; }
.lchsp .events-featured-date { background: var(--ink); color: var(--paper); padding: 40px; display: flex; flex-direction: column; }
.lchsp .events-featured-save { color: color-mix(in srgb, var(--paper) 75%, transparent); }
.lchsp .events-featured-big { font-family: var(--serif); font-size: clamp(72px, 9vw, 120px); line-height: 0.95; letter-spacing: -0.03em; margin: 24px 0 16px; }
.lchsp .events-featured-year { color: color-mix(in srgb, var(--teal) 55%, var(--paper)); } /* AA: lighten teal on ink */
.lchsp .events-featured-meta { margin-top: auto; padding-top: 40px; display: flex; flex-direction: column; gap: 10px; font-size: 15px; color: color-mix(in srgb, var(--paper) 92%, transparent); }
.lchsp .events-featured-note { font-style: italic; color: color-mix(in srgb, var(--paper) 78%, transparent); margin-top: 8px; font-size: 13px; }
.lchsp .events-featured-detail { padding: 40px; display: flex; flex-direction: column; }
.lchsp .events-featured-chip { align-self: flex-start; margin-bottom: 16px; }
.lchsp .events-featured-title { font-size: clamp(28px, 3vw, 42px); }
.lchsp .events-featured-subtitle { font-family: var(--serif); font-style: italic; font-size: 20px; color: var(--teal); margin-top: 8px; }
.lchsp .events-featured-desc { font-size: 16px; color: var(--ink-60); margin-top: 20px; }
.lchsp .events-agenda-label { margin: 24px 0 12px; }
.lchsp .events-agenda { display: flex; flex-direction: column; }
.lchsp .events-agenda-row { display: grid; grid-template-columns: 60px 1fr; gap: 16px; padding: 10px 0; border-top: 1px solid var(--rule); font-size: 14px; }
.lchsp .events-featured-actions { margin-top: 28px; gap: 10px; }

/* Connect series */
.lchsp .events-connect-section { padding: 0 0 16px; }
.lchsp .events-connect { background: var(--navy-deep); color: var(--paper); border-radius: 14px; padding: clamp(32px, 4vw, 56px); display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; align-items: center; }
.lchsp .events-connect h2 { margin-top: 16px; }
.lchsp .events-connect h2 em { font-style: italic; }
.lchsp .events-connect-desc { opacity: 0.85; font-size: 16px; max-width: 540px; margin-top: 12px; }
.lchsp .events-connect-actions { margin-top: 24px; gap: 10px; }
.lchsp .events-connect-card { padding: 24px; border-radius: 12px; background: color-mix(in srgb, var(--paper) 8%, transparent); border: 1px solid color-mix(in srgb, var(--paper) 20%, transparent); }
.lchsp .events-connect-card-label { color: color-mix(in srgb, var(--paper) 72%, transparent); margin-bottom: 12px; }
.lchsp .events-connect-legis { display: flex; flex-direction: column; gap: 8px; font-family: var(--serif); font-size: 16px; }

/* Live calendar embed */
.lchsp .events-calendar-section { padding: 64px 0 96px; }
.lchsp .events-calendar-embed { border: 1px solid var(--rule); border-radius: 14px; overflow: hidden; background: var(--paper); }
.lchsp .events-calendar-embed iframe { display: block; width: 100%; height: clamp(560px, 75vh, 760px); border: 0; }

@media (max-width: 960px) {
  .lchsp .events-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .lchsp .events-featured { grid-template-columns: 1fr; }
  .lchsp .events-connect { grid-template-columns: 1fr; gap: 28px; }
}
