/* ═══════════════════════════════════════════════════════════
   FISHER CAMPAIGN — HEADER
   Layout:  [Logo LEFT]  [Nav CENTER]  [Donate RIGHT/FLUSH]
   Mobile:  [Logo LEFT]  [Hamburger RIGHT]
═══════════════════════════════════════════════════════════ */

.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  z-index: 9999;
  background: var(--navy);
  color: #fff;
  padding: 8px 16px;
  font-family: var(--font-sans);
  font-size: .9rem;
  transition: top .2s ease;
}
.skip-link:focus { top: 0; }

/* ── WordPress Admin Bar Offset ────────────────────────────
   WP admin bar is 32px tall on desktop, 46px on mobile.
   Fixed header must sit below it when user is logged in.    */
body.admin-bar .site-header     { top: 32px; }

@media screen and (max-width: 782px) {
  body.admin-bar .site-header   { top: 46px; }
}

/* ── Header shell ──────────────────────────────────────── */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  transition: background .3s ease, box-shadow .3s ease, top .2s ease;
}

/* Always solid navy — no transparent variant.
   The header is always visible on every page and on load. */
.site-header {
  background: #1c2753;
  box-shadow: 0 2px 20px rgba(0,0,0,.35);
}

/* ── Inner grid ────────────────────────────────────────── */
.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: stretch;
  height: 96px;
  padding: 0 0 0 24px;
  max-width: 100%;
  gap: 0;
  position: relative; /* anchor for nav panel */
}

/* ── Logo (left) ───────────────────────────────────────── */
.site-header__logo {
  display: flex;
  align-items: center;
  padding-right: 28px;
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  padding: 0;
  height: 100%;
}

.site-logo__img {
  display: block;
  height: 88px;
  width: auto;
  max-width: 320px;
  object-fit: contain;
  object-position: center;
  flex-shrink: 0;
}

.site-logo__text {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  gap: 3px;
}

.site-logo__name {
  display: block;
  font-family: var(--font-label);
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #fff;
}

.site-logo__tagline {
  display: block;
  font-family: var(--font-sans);
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
}

/* ── Nav (center) ──────────────────────────────────────── */
.site-header__nav {
  display: flex;
  align-items: center;
  padding: 0 16px;
}

.primary-nav { display: flex; align-items: center; }

.primary-nav__list {
  display: flex;
  align-items: center;
  list-style: none;
  margin: 0;
  padding: 0;
  gap: 0;
}

/* Link base — no underline at rest */
.primary-nav__list li a,
.primary-nav__link {
  display: inline-block;
  padding: 8px 14px;
  font-family: var(--font-label);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .2s ease, border-color .2s ease;
  white-space: nowrap;
}

/* Hover + active — red underline only */
.primary-nav__list li a:hover,
.primary-nav__list li.current-menu-item > a,
.primary-nav__list li.current-page-ancestor > a,
.primary-nav__link:hover {
  color: #fff;
  border-bottom-color: #C3151C;
}

/* ── Donate nav item — always hidden in the nav list ──────
   The dedicated red button (right column) is the only donate.
   Walker already skips menu-item-donate items, but this CSS
   acts as a second safety net for any edge case.              */
.primary-nav__list li.menu-item-donate { display: none !important; }
.primary-nav__list li a.nav-donate     { display: none !important; }

/* Dropdown sub-menus */
.primary-nav__list li { position: relative; }

.primary-nav__list .sub-menu {
  position: absolute;
  /* top: 100% with NO gap — gap was causing mouse to lose hover between parent and menu */
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  min-width: 200px;
  background: #1c2753;
  border-top: 3px solid #C3151C;
  border-radius: 0 0 6px 6px;
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
  list-style: none;
  /* padding-top creates hover bridge so cursor reaching sub-menu doesn't drop hover */
  padding: 8px 0 6px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  /* Show instantly, hide with small delay so JS click handler can fire */
  transition: opacity .15s ease, visibility .15s ease;
  z-index: 10;
}

/* CSS hover — keep open while inside li or sub-menu */
.primary-nav__list li:hover > .sub-menu,
.primary-nav__list li:focus-within > .sub-menu,
.primary-nav__list li.is-open > .sub-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.primary-nav__list .sub-menu li a {
  padding: 12px 20px;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #ffffff !important;
  border-bottom: none;
  display: block;
  transition: background .15s ease, color .15s ease;
}

.primary-nav__list .sub-menu li a:hover {
  background: rgba(255,255,255,.12);
  color: #ffffff !important;
  border-bottom: none;
  padding-left: 26px;
}

/* ── Donate CTA (right, square, full-height, flush edge) ── */
.site-header__cta {
  display: flex;
  align-items: stretch;
}

.header-donate-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 40px;
  background: #C3151C;
  color: #fff;
  font-family: var(--font-label);
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 0;
  border: none;
  white-space: nowrap;
  min-width: 120px;
  transition: background .2s ease;
}

.header-donate-btn:hover  { background: #a01017; color: #fff; }
.header-donate-btn:active { background: #8a0d14; }
.header-donate-btn:focus-visible { outline: 3px solid #fff; outline-offset: -4px; }

/* ── Hamburger (hidden on desktop) ────────────────────── */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 48px;
  height: 48px;
  background: transparent;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  padding: 10px;
  margin: auto 12px auto auto;
  transition: background .2s ease;
}

.nav-toggle:hover { background: rgba(255,255,255,.1); }
.nav-toggle:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }

.nav-toggle__bar {
  display: block;
  width: 22px;
  height: 2px;
  background: #fff;
  border-radius: 2px;
  transform-origin: center;
  transition: transform .3s ease, opacity .3s ease, width .3s ease;
}

.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) { opacity: 0; width: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ═══════════════════════════════════════════════════════════
   MOBILE ≤ 900px
═══════════════════════════════════════════════════════════ */

/* Desktop — mobile donate button must never show */
@media (min-width: 901px) {
  #mobile-donate-btn,
  .mobile-donate-btn { display: none !important; }
}
@media (max-width: 900px) {

  .site-header__inner {
    grid-template-columns: 1fr auto;
    grid-template-areas: "logo toggle";
    height: 72px;
    padding: 0 16px;
    align-items: center;
  }

  .site-header__logo { grid-area: logo; padding-right: 0; }
  .site-header__cta  { display: none !important; }  /* desktop donate hidden on mobile */
  .nav-toggle        { display: flex; grid-area: toggle; margin: 0; }
  .site-header__nav  { padding: 0; }

  /* Slide-down nav panel */
  .site-header__nav {
    grid-area: unset;
    grid-column: 1 / -1;
    position: absolute;
    top: 100%;             /* always flush to bottom of header — never a gap */
    left: 0;
    right: 0;
    background: #111830;
    border-top: 3px solid #C3151C;
    border-radius: 0;
    max-height: 0;
    overflow: hidden;
    visibility: hidden;
    transition: max-height .35s ease, visibility .25s ease;
    z-index: 999999;
  }

  .site-header__nav.is-open {
    max-height: 80vh;
    visibility: visible;
    overflow-y: auto;
  }

  /* Show the donate nav item on mobile */
  .primary-nav__list li.menu-item-donate {
    display: block;
  }

  .primary-nav,
  .primary-nav__list {
    flex-direction: column;
    align-items: stretch;
    margin: 0;
    padding: 0;
    width: 100%;
    gap: 0;
  }

  .primary-nav__list li a,
  .primary-nav__link {
    display: block;
    padding: 16px 24px;
    font-size: .88rem;
    border-bottom: 1px solid rgba(255,255,255,.07);
    border-left: 3px solid transparent;
    border-bottom-color: transparent;
    color: rgba(255,255,255,.8);
  }

  .primary-nav__list li a:hover,
  .primary-nav__list li.current-menu-item > a {
    background: rgba(255,255,255,.06);
    border-left-color: #C3151C;
    border-bottom-color: transparent;
    color: #fff;
  }

  /* Sub-menus flat on mobile */
  .primary-nav__list .sub-menu {
    position: static;
    transform: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    box-shadow: none;
    border-top: none;
    border-radius: 0;
    background: rgba(0,0,0,.2);
    padding: 0;
  }
  .primary-nav__list .sub-menu li a { padding-left: 40px; font-size: .8rem; }

  /* Mobile donate button — bottom of nav panel */
  .mobile-donate-btn {
    display: block;
    margin: 8px 16px 20px;
    padding: 14px 24px;
    background: #C3151C;
    color: #fff;
    font-family: var(--font-label);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 6px;
    text-align: center;
    transition: background .2s ease;
    width: calc(100% - 32px);
    box-sizing: border-box;
    position: relative; /* ensure it's in normal flow, not floating */
  }
  .mobile-donate-btn:hover { background: #a01017; color: #fff; }

  /* Mobile logo slightly smaller */
  .site-logo__img  { height: 72px; padding-top: 0; }
  .site-logo__name { font-size: 1rem; }

  /* Admin bar — mobile nav panel needs to account for 46px bar */
  /* admin-bar offset handled automatically by top:100% */
}

@media (max-width: 400px) {
  .site-logo__tagline {
    display: block;
    font-size: .55rem;
    letter-spacing: .14em;
    line-height: 1.4;
  }
  /* Each tagline part on its own line */
  .tagline-line1,
  .tagline-line2 { display: block; }
}
