:root{
  --primary: #C94F4F; /* brighter brick red suggestion */
  --primary-dark: #9B1B2B;
  --accent: #FFB84D;
  --bg: #F8F6F6;
  --card-bg: #ffffff;
  --muted: #4b4b4b;
  --text: #1e1e1e;
  --radius: 12px;
  --max-width: 1100px;
  --shadow: 0 6px 18px rgba(20,20,20,0.06);
  --glass: rgba(255,255,255,0.6);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  color:var(--text);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}

.container{max-width:var(--max-width);margin:0 auto;padding:1.25rem}

/* skip link */
.skip-link{
  position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{left:8px;top:8px;width:auto;height:auto;background:#000;color:#fff;padding:.5rem 1rem;border-radius:6px;z-index:9999}

/* header */
.site-header{
  background:linear-gradient(180deg, rgba(255,255,255,0.6), rgba(255,255,255,0.2));
  position:sticky;top:0;z-index:50;backdrop-filter: blur(6px);
  border-bottom:1px solid rgba(0,0,0,0.04);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0}
.brand{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text)}
.brand-logo{width:44px;height:auto}
.brand-title{font-family:"Montserrat";font-weight:700}
.nav{display:flex;align-items:center;gap:1rem}
.nav-links{display:flex;gap:.65rem;list-style:none;margin:0;padding:0}
.nav-links a{display:inline-block;padding:.45rem .6rem;border-radius:8px;text-decoration:none;color:var(--muted);font-weight:600}
.nav-links a:hover, .nav-links a:focus{background:var(--glass);color:var(--text)}
.nav-toggle{display:none;background:none;border:0;font-size:1.05rem;padding:.4rem;border-radius:8px}
.header-actions{display:flex;align-items:center;gap:.5rem}

/* announcement bar */
.announcement-bar{padding:.5rem .75rem;background:linear-gradient(90deg,var(--primary),var(--primary-dark));color:#fff;text-align:center;font-weight:600}
.announcement-bar a{color:inherit;text-decoration:underline}

/* hero */
.hero{padding:3.25rem 0;border-radius:12px;margin:1.5rem 0;background:linear-gradient(135deg, rgba(217,80,80,0.12), rgba(217,80,80,0.04));}
.hero-inner{display:flex;align-items:center;gap:2rem;flex-direction:column;text-align:center;padding:2rem;border-radius:12px}
.hero-logo{width:96px}
.hero-title{font-family:"Montserrat";font-size:2.2rem;margin:.25rem 0;color:var(--primary-dark)}
.hero-sub{max-width:780px;color:var(--muted)}
.hero-ctas{display:flex;gap:.6rem;margin-top:1rem;flex-wrap:wrap}
.btn{display:inline-block;padding:.6rem .95rem;border-radius:10px;text-decoration:none;font-weight:700;border:2px solid transparent;transition:transform .16s ease,box-shadow .16s ease}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--primary);color:white;box-shadow:var(--shadow);border-color:rgba(0,0,0,0.04)}
.btn-outline{background:transparent;border-color:var(--primary);color:var(--primary);}

/* sections */
.section{padding:1.25rem 0}
.section-header{display:flex;align-items:end;justify-content:space-between;gap:1rem;margin-bottom:.75rem}
.section-header h2{margin:0;font-family:"Montserrat";font-size:1.15rem}
.boxed{background:var(--card-bg);padding:1rem;border-radius:var(--radius);box-shadow:var(--shadow);}

/* cards grid */
.cards-grid {
  display: grid;
  gap: 2rem;
  margin-top: 2rem;
}

.cards-grid > .card, .cards-grid > div, .cards-grid > article {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  padding: 1.5rem;
  transition: box-shadow 0.2s;
}

.card:hover, .cards-grid > div:hover, .cards-grid > article:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
}

.card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
  position: relative;
  padding-bottom: 2.5em;
}
.card h3{margin:0;font-family:"Montserrat";font-size:1rem}
.card p{margin:0;color:var(--muted)}
.card .meta{font-size:.85rem;color:var(--muted)}

/* Leaders, Branches, Resources grid */
#leaders-grid,
#branches-grid,
#resources-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1.5rem;
  justify-content: center;
  margin-bottom: 2rem;
  max-width: 1100px;
}

/* Announcements grid */
#announcements-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1.5rem;
  align-items: stretch;
  margin-bottom: 2rem;
}

/* join grid & embed */
.join-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 2rem;
  align-items: start;
}
.join-copy { min-width: 0; }
.join-embed { min-width: 0; width: 100%; height: 100%; display: flex; flex-direction: column; justify-content: stretch; }
.join-embed iframe {
  width: 100%; height: 100%; min-height: 420px;
  border: 1px solid rgba(0,0,0,0.06); border-radius: 8px;
}
.embed-frame{min-height:420px}

/* leaders */
.leader {display:flex;gap:.8rem;align-items:center}
.leader img{width:64px;height:64px;border-radius:10px;object-fit:cover}
.prose p{margin:.75rem 0;color:var(--muted);}

/* leadership cards */
/* leadership cards */
.leadership-card {
  background: var(--card-bg);
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  padding: 1.25rem;
  text-align: center;
  width: 100%;
  max-width: 260px;
  margin: 0 auto;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.leadership-card img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 1rem;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/* leadership button row */
.leadership-actions {
  text-align: center;
  margin-top: 1.5rem;
}
.leadership-actions .btn {
  display: inline-block;
}

/* carousel */
.carousel{position:relative;overflow:hidden;border-radius:12px}
.carousel-track{display:flex;gap:.6rem;overflow-x:auto;scroll-snap-type:x mandatory;padding:1rem;scroll-behavior:smooth}
.carousel-item{min-width:240px;flex:0 0 auto;scroll-snap-align:center;background:linear-gradient(180deg,rgba(0,0,0,0.02),transparent);border-radius:10px;padding:.5rem}
.carousel-item img{width:100%;height:160px;object-fit:cover;border-radius:8px}
/* carousel buttons styling */
.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background-color: var(--primary); /* Light red */
  color: #fff;
  border-radius: 50%;
  padding: 0.5rem 0.6rem;
  box-shadow: var(--shadow);
  cursor: pointer;
  z-index: 10;
  font-size: 1.25rem;
  border: none;
}

/* Place left and right buttons outside the track */
.carousel-btn.left {
  left: -1rem; /* move left outside the cards */
}

.carousel-btn.right {
  right: -1rem; /* move right outside the cards */
}

.carousel-btn.right { right: 8px; }

/* announcements carousel */
#announcements-carousel {
  position: relative;
  margin-top: 1.5rem;
}

#announcements-list.carousel-track {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 1rem 0;
}

#announcements-list .announcement-card {
  flex: 0 0 calc(33.333% - 1rem); /* 3 per view on desktop */
  scroll-snap-align: start;
  min-width: 260px;
  max-width: 340px;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

/* Announcements carousel responsive */
@media (max-width: 900px) {
  #announcements-list .announcement-card {
    flex: 0 0 80%; /* 1 per view */
    max-width: none;
  }

  .carousel-btn {
    background-color: var(--primary); /* ensure buttons are red */
    color: white;
  }
}

/* footer */
.site-footer{padding:1rem 0;margin-top:2rem;border-top:1px solid rgba(0,0,0,0.06);background:transparent}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}

/* announcement card */
.announcement-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
  position: relative;
  padding-bottom: 2.5em;
}
.card-btn-wrap {
  margin-top: auto;
  display: flex;
  justify-content: center;
  padding-bottom: 0.5em;
}
.btn,
.announcement-btn {
  width: auto;
  min-width: 0;
  padding: 0.5em 1.2em;
  margin: 0 auto;
  display: inline-block;
}

/* modal */
.modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
.modal-content {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  max-width: 400px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  position: relative;
}
.modal-close {
  position: absolute;
  top: 1rem; right: 1rem;
  font-size: 1.5rem;
  cursor: pointer;
}

/* responsiveness */
@media (max-width:900px){
  .join-grid{grid-template-columns:1fr}
  .nav-links{display:none}
  .nav-toggle{display:inline-block}
  .header-inner{gap:.5rem}
}
@media (max-width:520px){
  .hero-title{font-size:1.6rem}
  .hero-inner{padding:1rem}
}
@media (min-width: 900px) {
  .join-embed { min-height: 520px; height: 100%; }
  .join-embed iframe { min-height: 520px; height: 100%; }
}

/* small helper */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.muted{color:var(--muted)}
code{background:rgba(0,0,0,0.03);padding:.1rem .35rem;border-radius:6px;font-family:monospace;font-size:.95em}
.join-embed .btn,
.join-embed .announcement-btn { margin-top: 2rem; }
/* ===========================
   Leadership — safe overrides
   Put this at the BOTTOM of style.css
   =========================== */

/* 1) Desktop: force exactly 4 columns when viewport is wide */
@media (min-width: 1100px) {
  #leaders-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-bottom: 2rem;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: 1rem;
  }
}

/* 2) Responsive base for smaller screens */
@media (max-width: 1099px) {
  #leaders-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5rem;
    margin-bottom: 2rem;
    max-width: var(--max-width);
    margin-inline: auto;
    padding-inline: 1rem;
  }
}

/* 3) Make every direct child of the grid (except the actions wrapper) look like a card.
   Using :not(.leadership-actions) prevents the actions wrapper from getting card styles. */
#leaders-grid > *:not(.leadership-actions) {
  background: var(--card-bg);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 1.25rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  text-align: center;
  width: 100%;
  max-width: 360px;
  justify-self: center;
}

/* 4) Consistent square headshots (rounded-square). Scoped to leadership cards only.
   Re-asserted to avoid accidental overrides. */
#leaders-grid > *:not(.leadership-actions) img,
#leaders-grid img.leader-headshot {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 12px;
  display: block;
  margin: 0 auto 1rem auto;
}

/* 5) Center the "See All Leadership" button wrapper without making it a white card.
   Targets only when the wrapper is a direct child of the grid. */
#leaders-grid > .leadership-actions {
  background: transparent;
  box-shadow: none;
  border: none;
  padding: 0;
  max-width: none;
  width: 100%;
  justify-self: center;
  display: flex;
  justify-content: center;
  margin-top: 1.5rem;
}

/* Fallback: if the button is a bare anchor inside the grid but not wrapped,
   target a common id (#see-all-leadership) or the .leadership-actions container. */
#see-all-leadership.btn,
.leadership-actions .btn {
  background: transparent;
  border: 2px solid var(--primary);
  color: var(--primary);
  box-shadow: none;
  padding: .55rem 1rem;
  border-radius: 10px;
  display: inline-block;
  text-decoration: none;
}

/* Optional: alternate filled primary look (uncomment if desired)
#see-all-leadership.btn,
.leadership-actions .btn {
  background: var(--primary);
  color: #fff;
  border: 2px solid rgba(0,0,0,0.04);
  box-shadow: var(--shadow);
}
*/

/* 6) Responsive avatar size on small screens */
@media (max-width: 600px) {
  #leaders-grid > *:not(.leadership-actions) img,
  #leaders-grid img.leader-headshot {
    width: 96px;
    height: 96px;
    border-radius: 10px;
  }
}

.cards-grid > .leadership-actions,
#leaders-grid > .leadership-actions {
  background: transparent !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
}
/* ========= Announcements carousel: final overrides (paste at BOTTOM of style.css) ========= */

/* container: allow buttons to sit outside track and not be clipped */
#announcements-carousel,
#announcements-carousel.carousel {
  position: relative !important;
  overflow: visible !important;           /* allow buttons outside the track */
  padding-inline: 2.5rem !important;      /* breathing room so buttons sit outside cards */
  margin-top: 1.25rem !important;
}

/* Force the track to a horizontal flex container (override previous grid) */
#announcements-carousel .carousel-track,
#announcements-list.carousel-track,
#announcements-list {
  display: flex !important;
  gap: 1rem !important;
  overflow-x: auto !important;
  scroll-snap-type: x mandatory !important;
  padding: 1rem 0 !important;
  -webkit-overflow-scrolling: touch !important;
}

/* Clear any grid-template left by earlier rules */
#announcements-list,
#announcements-list.carousel-track {
  grid-template-columns: none !important;
}

/* Slide sizing: 3 per view on wide screens */
#announcements-list > .card.announcement-card,
#announcements-carousel .announcement-card {
  flex: 0 0 calc(33.333% - 1rem) !important; /* 3 per view */
  scroll-snap-align: start !important;
  min-width: 260px !important;
  max-width: 340px !important;
  box-sizing: border-box !important;
}

/* Mobile: 1 card per view */
@media (max-width: 900px) {
  #announcements-list > .card.announcement-card,
  #announcements-carousel .announcement-card {
    flex: 0 0 86% !important;
    min-width: 220px !important;
    max-width: none !important;
  }
}
@media (max-width: 520px) {
  #announcements-list > .card.announcement-card,
  #announcements-carousel .announcement-card {
    flex: 0 0 92% !important;
  }
}

/* Buttons: high contrast, visible, large hit area, ensure pointer events */
.carousel-btn {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: var(--primary) !important;      /* red color */
  color: #fff !important;
  font-size: 1.25rem !important;
  border-radius: 999px !important;
  border: none !important;
  padding: 0.6rem 0.8rem !important;
  box-shadow: var(--shadow) !important;
  cursor: pointer !important;
  z-index: 9999 !important;
  opacity: 0.98 !important;
  pointer-events: auto !important;
  touch-action: manipulation; /* better touch behavior for buttons */
}

/* position inside the padded area so they do not overlap card content */
.carousel-btn.left { left: 8px !important; }
.carousel-btn.right { right: 8px !important; }

.carousel-btn:hover,
.carousel-btn:focus {
  transform: translateY(-50%) scale(1.06) !important;
  opacity: 1 !important;
}

/* Slightly bigger tap target on small phones */
@media (max-width: 520px) {
  .carousel-btn { padding: 0.75rem 1rem !important; font-size: 1.35rem !important; }
}
