/* ============================================================
   RESPONSIVE — breakpoint overrides
   ============================================================ */

@media (max-width: 1080px) {
  .cards { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 920px) {
  .hero p { font-size: 18px; }
  .hero {
    background-image:
      linear-gradient(180deg, rgba(250,248,245,.94) 0%, rgba(250,248,245,.7) 55%, rgba(250,248,245,.3) 100%),
      url("../assets/hero-skyline.png");
    background-position: center top;
  }
}

@media (max-width: 760px) {
  .nav-links { display: none; }
  .nav-links.open {
    display: flex; flex-direction: column; gap: 6px; align-items: stretch;
    position: absolute; top: 92px; left: 0; right: 0; background: var(--bg);
    border-bottom: 1px solid var(--line); padding: 18px var(--gut) 26px;
  }
  .nav-links.open a { padding: 10px 0; }
  .nav-links.open .btn { justify-content: center; margin-top: 8px; }
  .menu-btn { display: block; }
  .nav .nav-links > .btn { display: none; }
  .nav-links.open > .btn { display: inline-flex; }
}

@media (max-width: 620px) {
  .cards { grid-template-columns: repeat(2, 1fr); }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .foot-brand { grid-column: 1 / -1; }
  .contact-col { grid-column: 1 / -1; }
}

@media (max-width: 440px) {
  .cards { grid-template-columns: 1fr; }
  .cta-inner { flex-direction: column; align-items: flex-start; }
}
