/* ================================================================
   ACForyouth.org — ADDITIONAL CSS
   Location: Appearance → Customize → Additional CSS
   Purpose:  Shared variables, fonts, nav tweaks, and global resets
             used across all Custom HTML blocks on the homepage.
   ================================================================ */

/* ── Google Fonts ─────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@700;800;900&family=Source+Sans+3:wght@400;600;700&display=swap');

/* ── CSS Custom Properties (shared across all blocks) ─────────── */
:root {
  --acf-blue:       #005994;
  --acf-blue-dark:  #004272;
  --acf-blue-light: #0072bb;
  --acf-orange:     #f48120;
  --acf-orange-dark:#d46a10;
  --acf-grey:       #ced4da;
  --acf-grey-dark:  #a9b2bb;
  --acf-white:      #ffffff;
  --acf-text:       #333333;
  --acf-radius:     8px;
  --acf-shadow:     0 4px 24px rgba(0,0,0,.13);
  --acf-font-head:  'Barlow Condensed', sans-serif;
  --acf-font-body:  'Source Sans 3', sans-serif;
  --acf-transition: .25s cubic-bezier(.4,0,.2,1);
}

/* ── Prevent theme from over-constraining full-width blocks ─────
   BigSlam sometimes wraps content in a max-width container.
   This ensures our full-width sections bleed edge-to-edge.       */
.acf-homepage-block {
  width: 100%;
  max-width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* ── Universal box-sizing reset inside all ACF blocks ────────── */
.acf-homepage-block *,
.acf-homepage-block *::before,
.acf-homepage-block *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.acf-homepage-block {
  font-family: var(--acf-font-body);
  color: var(--acf-text);
  line-height: 1.6;
  overflow-x: hidden;
}

/* ── Shared inner container ────────────────────────────────────── */
.acf-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ── Shared section header ─────────────────────────────────────── */
.acf-sec-header {
  text-align: center;
  margin-bottom: 48px;
}
.acf-sec-tag {
  display: inline-block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--acf-orange);
  margin-bottom: 10px;
}
.acf-sec-title {
  font-family: var(--acf-font-head);
  font-size: clamp(1.9rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--acf-blue);
  text-transform: uppercase;
  line-height: 1.1;
}
.acf-sec-divider {
  width: 60px;
  height: 4px;
  background: var(--acf-orange);
  margin: 14px auto 0;
  border-radius: 2px;
}

/* ── Shared button styles ──────────────────────────────────────── */
.acf-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--acf-font-body);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .04em;
  text-decoration: none !important;
  padding: 14px 34px;
  border-radius: var(--acf-radius);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--acf-transition);
  white-space: nowrap;
  line-height: 1;
}
.acf-btn--orange {
  background: var(--acf-orange);
  color: var(--acf-white) !important;
  border-color: var(--acf-orange);
  box-shadow: 0 4px 18px rgba(244,129,32,.4);
}
.acf-btn--orange:hover {
  background: var(--acf-orange-dark);
  border-color: var(--acf-orange-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 26px rgba(244,129,32,.5);
  color: var(--acf-white) !important;
}
.acf-btn--outline-blue {
  background: transparent;
  color: var(--acf-white) !important;
  border-color: var(--acf-white);
}
.acf-btn--outline-blue:hover {
  background: var(--acf-blue);
  border-color: var(--acf-blue);
  transform: translateY(-2px);
  color: var(--acf-white) !important;
}
.acf-btn--outline-blue-solid {
  background: transparent;
  color: var(--acf-blue) !important;
  border-color: var(--acf-blue);
}
.acf-btn--outline-blue-solid:hover {
  background: var(--acf-blue);
  color: var(--acf-white) !important;
  transform: translateY(-2px);
}

/* ────────────────────────────────────────────────────────────────
   NAV BAR ENHANCEMENTS
   These rules polish your existing BigSlam nav — no restructuring.
   ──────────────────────────────────────────────────────────────── */

/* Ensure the orange bottom border accent under the full nav stays */
.site-header,
#site-header,
.navbar,
header.site-header {
  border-bottom: 3px solid var(--acf-orange);
}

/* Active / current page nav item matches orange highlight */
.main-navigation .current-menu-item > a,
.nav-menu .current-menu-item > a,
.main-navigation .current_page_item > a {
  background-color: var(--acf-orange) !important;
  color: var(--acf-white) !important;
}

/* Nav link hover state */
.main-navigation ul li a:hover,
.nav-menu li a:hover {
  color: var(--acf-orange) !important;
}

/* Donate menu item — make it stand out as a CTA */
.main-navigation .menu-item a[href*="donate"],
.nav-menu .menu-item a[href*="donate"] {
  color: var(--acf-orange) !important;
  font-weight: 700;
}
.main-navigation .menu-item a[href*="donate"]:hover,
.nav-menu .menu-item a[href*="donate"]:hover {
  background: var(--acf-orange) !important;
  color: var(--acf-white) !important;
}

/* Mobile hamburger — make sure it shows on small screens */
@media (max-width: 768px) {
  .menu-toggle {
    color: var(--acf-blue) !important;
    border-color: var(--acf-blue) !important;
  }
  /* Slide-in mobile menu background */
  .main-navigation ul.nav-menu,
  .main-navigation div.menu {
    background: var(--acf-blue-dark);
  }
  .main-navigation ul li a,
  .nav-menu li a {
    color: var(--acf-white) !important;
    border-bottom: 1px solid rgba(255,255,255,.1);
  }
}