/* ============================================================
   Gridkast & Co. — Responsive (v2)
   ============================================================ */

@media (max-width: 1100px) {
  .container { padding: 0 24px; }
  .hero-grid { gap: 44px; }
  .svc-grid, .pkg-grid, .cap-grid { grid-template-columns: repeat(2,1fr); }
  .ind-grid { grid-template-columns: repeat(4,1fr); }
  .foot-grid { grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; }
}

@media (max-width: 960px) {
  .section { padding: 80px 0; }
  .section-sm { padding: 56px 0; }

  /* Hero stacks */
  #hero { padding: 132px 0 72px; }
  .hero-grid { grid-template-columns: 1fr; gap: 52px; }
  .hero-lead { max-width: 560px; }
  .hero-visual { max-width: 520px; }

  /* Process becomes 2-col, drop connector */
  .process { grid-template-columns: repeat(2,1fr); gap: 28px; }
  .step::before { display: none; }

  /* Grids */
  .cols-3, .cols-4 { grid-template-columns: repeat(2,1fr); }
  .why-grid { grid-template-columns: repeat(2,1fr); }

  /* Trust strip wraps */
  .trust-cell { flex: 1 1 33%; border-bottom: 1px solid var(--line-soft); }

  /* Contact stacks */
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }

  /* About split stacks */
  .about-split { grid-template-columns: 1fr !important; gap: 40px !important; }

  /* Footer */
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
}

@media (max-width: 760px) {
  .section { padding: 64px 0; }

  /* Header → mobile */
  .main-nav { display: none; }
  .header-cta .btn-primary { display: none; }
  .hamburger { display: flex; }

  /* Hero */
  .hero-h1 { font-size: 34px; }
  .hero-btns { flex-direction: column; align-items: stretch; }
  .hero-btns .btn { justify-content: center; }
  .hero-trust { gap: 18px; flex-wrap: wrap; }

  /* Single-column everything */
  .svc-grid, .pkg-grid, .cap-grid, .cols-2, .cols-3, .cols-4, .why-grid { grid-template-columns: 1fr; }
  .ind-grid { grid-template-columns: repeat(3,1fr); }
  .process { grid-template-columns: 1fr; gap: 22px; }
  .step { padding-left: 4px; }

  /* Trust strip stacks */
  .trust-cell { flex: 1 1 50%; }

  /* Form */
  .form-row { grid-template-columns: 1fr; }
  .form-card { padding: 26px; }

  /* CTA */
  .cta-band { padding: 44px 26px; }
  .cta-btns { flex-direction: column; align-items: stretch; }
  .cta-btns .btn { justify-content: center; }

  /* Packages: feature first */
  .pkg.feat { order: -1; }

  /* Footer */
  .foot-grid { grid-template-columns: 1fr; gap: 32px; }
  .foot-bottom { flex-direction: column; text-align: center; }
}

@media (max-width: 460px) {
  .container { padding: 0 18px; }
  .section { padding: 56px 0; }
  .head-wrap { margin-bottom: 40px; }
  .h-title { font-size: 26px; }
  .hero-h1 { font-size: 30px; }
  .ind-grid { grid-template-columns: repeat(2,1fr); }
  .hero-trust { gap: 14px; }
  .hero-divider { display: none; }
  .cta-band { padding: 36px 22px; }
  .foot-legal { flex-direction: column; gap: 8px; }
}

/* Accessibility */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
}

@media print {
  #site-header, #site-footer, #back-top, .mobile-nav, .cta-band { display: none; }
}
