/* ============================================================
   Responsive — laptop (1250px) + phone (768px)
   ============================================================ */
@media (max-width: 1250px) {
  .main-header { justify-content: center; }
  .header-left, .main-nav, .actions-right { flex: 1 1 100%; justify-content: center; }
  .membership-actions { margin-left: 2rem; }
  .cards-grid-3 { grid-template-columns: 1fr; gap: 2rem; }
  .split-feature { flex-direction: column; border-radius: var(--br-card); }
  .sf-image { min-height: 350px; }
  h1.mega-display { font-size: clamp(3rem, 10vw, 4rem); line-height: 1.1; }
  .hero-visual { min-height: 40vh; height: 50vh; border-radius: var(--br-card); }
}

@media (max-width: 768px) {
  html, body { overflow-x: hidden; }
  .container { padding: 0 6%; }

  /* Hero */
  .hero { padding-top: 2rem; padding-bottom: 1.5rem; }
  .hero-top-row { flex-direction: column; gap: 1.5rem; align-items: flex-start; }
  .hero-headline-wrap { min-width: 0; width: 100%; }
  .hero-sub-text-wrap { width: 100%; flex-basis: auto; }
  h1.mega-display { font-size: clamp(2.2rem, 8vw, 3rem); }
  .hero-visual { height: 40vh; min-height: 250px; border-radius: 16px; }

  /* Header: brand left, hamburger right; full nav lives in the mobile menu */
  .main-header { flex-direction: row; flex-wrap: nowrap; justify-content: space-between; align-items: center; gap: 0.75rem; }
  .header-left { gap: 1rem; }
  .membership-actions { display: none; }
  .actions-right { display: none; }
  .main-nav { display: none; }
  .nav-toggle { display: block; }
  .mobile-menu.open { display: block; padding-top: 0.5rem; padding-bottom: 1.75rem; border-top: 1px solid rgba(var(--navy-rgb), 0.1); max-height: calc(100vh - 72px); overflow-y: auto; }

  /* Cards */
  .cards-grid-3 { grid-template-columns: 1fr; gap: 1.5rem; }
  .editorial-card { padding: 2.5rem 2rem; }
  .layout-pad { padding-top: 3rem; padding-bottom: 3rem; }

  /* Split feature */
  .split-feature { flex-direction: column; margin: 3rem 0; border-radius: 16px; }
  .sf-content { padding: 2rem 1.5rem; }
  .sf-content h2 { font-size: 1.8rem; }
  .sf-image { min-height: 250px; }

  /* News cards */
  .news-card img { height: 160px; }
  .news-card-body { padding: 1.5rem; }

  /* Events */
  .event-row { flex-direction: column; align-items: flex-start; gap: 0.75rem; padding: 1.25rem 1.5rem; }

  /* Newsletter */
  .newsletter-panel { padding: 2.5rem 1.5rem; flex-direction: column; text-align: center; }
  .newsletter-form { flex-direction: column; width: 100%; }
  .newsletter-form input { min-width: 0; width: 100%; }
  .newsletter-form .btn { width: 100%; }

  /* Footer */
  .footer-top { flex-direction: column; gap: 2.5rem; }
  .footer-cols { flex-direction: column; gap: 2.5rem; }

  /* Section headers */
  .section-header-block { flex-direction: column; align-items: flex-start; gap: 1rem; }
  h2 { font-size: clamp(1.8rem, 6vw, 2.5rem); }

  /* Utility bar hidden on mobile (its links live in the mobile menu) */
  .utility-bar { display: none; }
}
