/* =====================================================================
   Stake-Bet.ca — Responsive overrides (mobile-first cascade)
   ===================================================================== */

/* ---------- Tablet & below ---------- */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .hero-media { order: -1; max-width: 520px; }
  .promo-card { grid-template-columns: 1fr; gap: 26px; padding: 30px; }
  .footer-cols { grid-template-columns: 1fr 1fr; gap: 28px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }

  /* Collapsing navigation */
  .menu-toggle { display: inline-flex; }
  .main-navigation {
    position: absolute; top: 100%; left: 0; right: 0;
    background: var(--c-surface); border-bottom: 1px solid var(--c-line);
    box-shadow: var(--shadow-md);
    max-height: 0; overflow: hidden; transition: max-height .28s ease;
    margin-left: 0;
  }
  .main-navigation.open { max-height: 560px; }
  .main-navigation ul { flex-direction: column; align-items: stretch; gap: 0; padding: 10px var(--gutter) 16px; }
  .main-navigation a { padding: 13px 12px; border-radius: 8px; font-size: 1rem; }
  .site-header { position: sticky; }
}

/* ---------- Small tablets / large phones ---------- */
@media (max-width: 760px) {
  .section { padding: 48px 0; }
  .grid-3, .grid-2 { grid-template-columns: 1fr; }
  .proscons { grid-template-columns: 1fr; }
  .media-band { grid-template-columns: 1fr; gap: 28px; }
  .media-band--reverse .media-figure { order: 0; }
  .media-band .media-figure { order: -1; }
  .stat-band { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; gap: 6px; }
  .hero-section { padding: 52px 0 56px; }
  .hero-cta .btn, .hero-cta .cta-button { flex: 1 1 auto; }
}

/* ---------- Phones ---------- */
@media (max-width: 480px) {
  body { font-size: 16px; }
  .footer-cols { grid-template-columns: 1fr; gap: 26px; }
  .grid-4 { grid-template-columns: 1fr; }
  .code-box { flex-direction: column; align-items: stretch; text-align: center; gap: 14px; }
  .code-value { font-size: 1.7rem; }
  .copy-btn { width: 100%; padding: 14px; }
  .step { grid-template-columns: 38px 1fr; gap: 14px; padding: 18px; }
  .step::before { width: 38px; height: 38px; font-size: 1rem; }
  .header-actions .btn-sm { padding: 8px 14px; font-size: .82rem; }
  .promo-card { padding: 22px; }
}

/* ---------- Motion preferences ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { transition: none !important; scroll-behavior: auto !important; }
}
