/* ══════════════════════════════════════════════════════════
   responsive.css
   all @media queries · mobile-first order · matching
   section order from sections.css
   ══════════════════════════════════════════════════════════ */

/* ── 560px — nav CTA hide ── */
@media(max-width:560px) {
  .nav-cta {
    display: none;
  }
}

/* ── 600px — container & nav-inner padding ── */
@media(max-width:600px) {
  .container {
    padding: 0 20px;
  }
}

@media(max-width:600px) {
  .nav-inner {
    padding: 0 20px;
  }
}

/* ── 760px — services detail items single column ── */
@media(max-width:760px) {
  .detail-items {
    grid-template-columns: 1fr;
  }
}

/* ── 768px — section padding · review cards · contact grid · footer ── */
@media(max-width:768px) {
  section {
    padding: 72px 0;
  }
}

/* ── 1100px — reviews: 2 cards no longer fit; revert to 400 px cards ── */
@media(max-width:1100px) {
  .review-card {
    min-width: 400px;
    max-width: 400px;
  }
}

@media(max-width:768px) {
  .review-card {
    min-width: calc(100vw - 40px);
    max-width: calc(100vw - 40px);
  }

  /* remove carousel safe-zone indent on small screens */
  .reviews .carousel-wrap {
    padding-left: 0;
  }
}

@media(max-width:768px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .form-row {
    grid-template-columns: 1fr;
  }

  .contact-grid>div:first-child {
    order: 2;
  }

  .contact-right {
    order: 1;
  }
}

@media(max-width:768px) {
  .footer-top {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ── 880px — hero stacked layout ── */
@media(max-width:880px) {
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 0;
    padding-bottom: 0;
  }

  .hero-img-col {
    order: -1;
    margin-bottom: 48px;
  }

  .hero-portrait {
    max-width: 280px;
    margin: 0 auto;
  }

  .hero-img-frame::before,
  .hero-img-frame::after {
    display: none;
  }

  .hero-badge {
    left: 50%;
    transform: translateX(-60%);
    bottom: 20px;
  }

  .hero-stats {
    flex-wrap: wrap;
  }

  .hero-stat {
    padding: 20px 32px 20px 0;
    margin-right: 32px;
  }
}

/* ── 900px — services radial hidden, accordion shown ── */
@media(max-width:900px) {
  .radial-wrap {
    display: none;
  }

  .service-detail {
    display: none !important;
  }

  .services-accordion {
    display: block;
  }
}

/* ── 960px — about stacked · nav hamburger ── */
@media(max-width:960px) {
  .about-inner {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .about-img-wrap {
    max-width: 320px;
    margin: 0 auto;
  }

  .about-img-wrap::before {
    display: none;
  }
}

@media(max-width:960px) {
  .nav-links {
    display: none;
  }

  .hamburger {
    display: flex;
  }

  .mobile-menu {
    display: block;
  }
}

/* ── 768px — sigil strip smaller · tighter safe zone on mobile ── */
@media(max-width:768px) {
  svg.sigil-rule {
    height: 20px;
    width: calc(100% + 12px);
    margin-left: -12px;
    margin-top: 12px;
    margin-bottom: 18px;
  }

  .hero-content,
  .services-header,
  .reviews-header {
    padding-left: 12px;
  }
}
