  /* ─── Announcement bar (mirrors their site) ─── */
  .announce {
    background: var(--navy-deep);
    color: var(--steel);
    font-family: var(--cond);
    font-weight: 500;
    font-size: 12.5px;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    padding: 11px 44px;
    display: flex; justify-content: center; align-items: center; gap: 22px;
    border-bottom: 1px solid rgba(169,183,206,0.1);
    position: relative;
  }
  .announce::before,
  .announce::after {
    content: ""; position: absolute; bottom: -1px; height: 1px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity: 0.35; width: 30%;
  }
  .announce::before { left: 0; }
  .announce::after  { right: 0; }
  .announce .pipe {
    color: transparent;
    width: 5px; height: 5px; border-radius: 50%;
    background: var(--accent); opacity: 0.7;
    font-size: 0;
  }
  .announce a { color: var(--ivory); text-decoration: none; transition: color .2s; }
  .announce a:hover { color: var(--accent); }
  .announce .phone { color: var(--ivory); font-weight: 600; letter-spacing: 0.16em; }

  /* ─── Top nav (dark navy, matches their site header) ─── */
  .topbar {
    position: sticky; top: 0; z-index: 80;
    background: linear-gradient(180deg, var(--navy) 0%, var(--navy-600) 100%);
    border-bottom: 1px solid rgba(169,183,206,0.12);
    box-shadow: 0 2px 12px rgba(8,22,41,0.2);
  }
  .topbar-inner {
    max-width: 1440px; margin: 0 auto;
    padding: 16px 44px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 40px;
  }
  .brand {
    display: flex; align-items: center; gap: 16px;
    text-decoration: none; color: var(--ivory);
  }
  .brand-mark {
    width: 56px; height: 56px;
    display: grid; place-items: center;
  }
  .brand-mark img {
    width: 56px; height: 56px;
    object-fit: contain;
    display: block;
  }
  .brand-text { display: flex; flex-direction: column; line-height: 1; }
  .brand-text .wordmark {
    font-family: var(--display);
    font-weight: 600;
    font-size: 22px;
    letter-spacing: 0.06em;
    color: var(--ivory);
    text-transform: uppercase;
  }
  .brand-text .wordmark .impact { color: var(--accent); font-weight: 500; }
  .brand-text .subline {
    font-family: var(--mono);
    font-size: 9.5px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--steel-deep);
    margin-top: 7px;
  }

  nav.tabs {
    display: flex; justify-content: center; align-items: center;
    gap: 2px;
  }
  .tab {
    position: relative;
    background: transparent; border: 0; cursor: pointer;
    font-family: var(--cond);
    font-weight: 600;
    font-size: 13.5px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--steel);
    padding: 14px 22px;
    border-radius: 2px;
    transition: color .2s, background .25s;
  }
  .tab:hover { color: var(--ivory); }
  .tab.active { color: var(--ivory); }
  .tab.active::after {
    content:""; position:absolute;
    left: 20px; right: 20px; bottom: 6px;
    height: 2px; background: var(--accent);
  }

  .top-right { display: flex; align-items: center; gap: 18px; }
  .top-meta {
    font-family: var(--mono); font-size: 10px;
    letter-spacing: 0.24em; text-transform: uppercase;
    color: var(--steel);
    display: inline-flex; align-items: center; gap: 8px;
  }
  .top-meta .dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 0 0 rgba(201,169,97,0.6);
    animation: pulse-dot 2.2s ease-out infinite;
  }
  @keyframes pulse-dot {
    0%   { box-shadow: 0 0 0 0 rgba(201,169,97,0.55); }
    70%  { box-shadow: 0 0 0 8px rgba(201,169,97,0); }
    100% { box-shadow: 0 0 0 0 rgba(201,169,97,0); }
  }
  .donate-top {
    appearance: none; border: 0;
    background: var(--accent); color: var(--navy-deep);
    font-family: var(--cond); font-weight: 700; font-size: 12.5px;
    letter-spacing: 0.22em; text-transform: uppercase;
    padding: 13px 20px;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 12px;
    border-radius: 2px;
    transition: background .2s, transform .15s, box-shadow .2s;
    box-shadow: 0 6px 18px -6px rgba(201,169,97,0.45);
  }
  .donate-top:hover { background: var(--accent-bright); transform: translateY(-1px); box-shadow: 0 12px 26px -10px rgba(201,169,97,0.6); }
  .donate-top:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
  .donate-top .arr { transition: transform .2s; }
  .donate-top:hover .arr { transform: translateX(3px); }

  /* Universal focus ring for keyboard users */
  .tab:focus-visible,
  .brand:focus-visible,
  .announce a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 2px;
  }
