/* ============================================================
   Subscale — Responsive
   Mobile-first refinements layered on top of style.css.
   Breakpoints: 1024 / 860 / 600 / 420
   ============================================================ */

/* ---------- Large tablet / small laptop ---------- */
@media (max-width: 1024px) {
  .cards--4 { grid-template-columns: repeat(2, 1fr); }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .cred-grid { grid-template-columns: repeat(2, 1fr); }

  .hero__grid { grid-template-columns: 1fr; gap: 50px; }
  .hero__copy { max-width: 640px; }
  .hero__visual { max-width: 560px; }

  .float-chip--1 { left: 0; }
  .float-chip--2 { right: 0; }

  .founder { grid-template-columns: 1fr; gap: 32px; }
  .founder__media { max-width: 360px; }

  .metrics { grid-template-columns: repeat(2, 1fr); }
}

/* ---------- Tablet ---------- */
@media (max-width: 860px) {
  /* Single-goal mobile header: logo + one CTA, no navigation */
  .nav__links { display: none; }
  .nav__actions { display: block; }

  /* Desktop floating CTA is replaced by the sticky bottom bar on mobile */
  .float-cta { display: none; }

  .timeline { grid-template-columns: repeat(2, 1fr); gap: 36px 24px; }
  .timeline::before { display: none; }

  .guarantee { flex-direction: column; gap: 22px; text-align: left; }

  .footer__grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer__brand { grid-column: 1 / -1; }

  .compare__row { grid-template-columns: 1fr 0.9fr 0.9fr; }
  .compare__feature, .compare__col { padding: 15px 14px; font-size: 13.5px; }

  .proof__stats { grid-template-columns: repeat(2, 1fr); gap: 28px 18px; }
  .case-panel__grid { grid-template-columns: 1fr; gap: 24px; }

  /* How It Works: stack to a single column, point connectors downward.
     Rotate the inner SVG (the <li> is a data-reveal target, so rotating
     it directly gets overridden by the reveal transform). */
  .steps { grid-template-columns: 1fr; gap: 14px; }
  .step__arrow { padding: 2px 0; }
  .step__arrow svg { transform: rotate(90deg); }

  .footer__row { flex-direction: column; align-items: flex-start; gap: 18px; }
}

/* ---------- Mobile ---------- */
@media (max-width: 600px) {
  body { font-size: 16px; }

  .cards--3,
  .cards--4 { grid-template-columns: 1fr; }
  .stats { grid-template-columns: 1fr 1fr; gap: 14px; }
  .cred-grid { grid-template-columns: 1fr; }
  .cta-form__grid { grid-template-columns: 1fr; }
  .founder__media { max-width: none; }
  .visual-note { position: static; display: block; text-align: center; margin-top: 10px; }

  .metrics { grid-template-columns: 1fr 1fr; }
  .qualify { grid-template-columns: 1fr; }
  .case-out { flex-direction: row; flex-wrap: wrap; gap: 8px 18px; }

  /* Reveal sticky CTA on mobile + keep content clear of it */
  .sticky-cta { display: block; }
  body { padding-bottom: 76px; }

  /* Booking calendar stacks on mobile */
  .cal { grid-template-columns: 1fr; }
  .cal__days { flex-direction: row; overflow-x: auto; max-height: none; padding-bottom: 4px; }
  .cal__day { flex: 0 0 auto; min-width: 116px; }

  /* Minimal footer centers */
  .footer__min { flex-direction: column; text-align: center; gap: 16px; }
}

  .hero { padding-top: 120px; }
  .hero__cta { flex-direction: column; align-items: stretch; }
  .hero__cta .btn { width: 100%; }
  .hero__meta { gap: 16px; }
  .hero__meta-divider { display: none; }
  .hero__meta-item { flex: 1 1 40%; }

  .dashboard__foot { grid-template-columns: 1fr; }
  .float-chip { display: none; } /* avoid clutter / overflow on small screens */

  .cta-form__row { grid-template-columns: 1fr; }

  .testimonial__foot { flex-direction: column; align-items: flex-start; }
  .testimonial__metric { text-align: left; }

  .footer__bar { flex-direction: column; align-items: flex-start; }
  .footer__fine { text-align: left; max-width: none; }

  /* Comparison becomes stacked, readable cards */
  .compare__row--head { display: none; }
  .compare__row { grid-template-columns: 1fr; gap: 0; padding: 6px 0 14px; }
  .compare__feature {
    font-weight: 700; color: var(--text); font-size: 15px;
    padding: 14px 18px 6px; text-transform: uppercase; letter-spacing: 0.04em;
  }
  .compare__col { border-left: none !important; padding: 8px 18px; font-size: 14.5px; }
  .compare__col--them::before { content: "Typical: "; color: var(--text-dim); font-weight: 600; }
  .compare__col--us { background: transparent; }
  .compare__col--us::before { content: "Subscale: "; color: var(--blue-bright); font-weight: 600; }
}

/* ---------- Small mobile ---------- */
@media (max-width: 420px) {
  :root { --gutter: 18px; }
  .stats { grid-template-columns: 1fr; }
  .section__title { font-size: 27px; }
  .hero__title { font-size: 36px; }
  .kpi { gap: 8px; }
  .kpi__card { padding: 11px; }
  .testimonial blockquote { font-size: 18px; }
}

/* ---------- Hover-capable devices only ---------- */
@media (hover: none) {
  .card:hover { transform: none; }
  [data-tilt] { transform: none !important; }
}
