/* ===== Tablet (max 1024) ===== */
@media (max-width: 1024px) {
  .hero-split { grid-template-columns: 1fr; gap: 48px; }
  .hero-text { max-width: 600px; margin: 0 auto; text-align: center; }
  .hero-buttons { justify-content: center; }
  .trust-row { justify-content: center; }
  .hero-visual { max-width: 420px; margin: 0 auto; }
  .float-card-1 { right: -8px; }
  .float-card-2 { left: -8px; }

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

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

  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid::before { display: none; }

  .results-grid { grid-template-columns: repeat(2, 1fr); gap: 32px; }
  .result-item:nth-child(2)::after { display: none; }

  .contact-layout { grid-template-columns: 1fr; }
}

/* ===== Mobile (max 768) ===== */
@media (max-width: 768px) {
  .nav-links {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    background: var(--bg);
    flex-direction: column;
    padding: 100px 32px 40px;
    gap: 0;
    z-index: 999;
    align-items: center;
    justify-content: flex-start;
  }
  .nav-links a:not(.nav-cta) {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--text);
    padding: 16px 0;
    border-bottom: 1px solid var(--border);
    width: 100%;
    text-align: center;
  }
  .nav-links a:not(.nav-cta)::after { display: none; }
  .nav-links .nav-cta {
    margin-top: 24px;
    width: 100%;
    text-align: center;
    justify-content: center;
    padding: 16px 24px;
    font-size: 1rem;
    border-radius: 12px;
  }
  .nav-links.open { display: flex; }
  .nav-toggle { display: flex; z-index: 1001; }
  .nav { z-index: 1002; }
  .nav.scrolled { background: var(--bg); }

  .hero { padding: 110px 0 48px; }
  .hero h1 { font-size: 2rem; }
  .hero-text { text-align: center; }
  .hero-text > p { font-size: .95rem; }

  /* Hide hero visual on mobile — iframe doesn't render well at small scale */
  .hero-visual { display: none; }

  .section { padding: 56px 0; }
  .section-head { margin-bottom: 32px; }
  .section-head h2 { font-size: 1.6rem; }

  /* Services: 1 column with compact cards */
  .services-grid { grid-template-columns: 1fr; gap: 14px; }
  .why-grid { grid-template-columns: 1fr; gap: 14px; }
  .service-card {
    padding: 24px 22px;
    display: flex;
    gap: 16px;
    align-items: flex-start;
  }
  .service-icon { margin-bottom: 0; flex-shrink: 0; }
  .service-card h3 { font-size: 1.05rem; margin-bottom: 4px; }
  .service-card p { font-size: .85rem; }

  /* Portfolio: full-width stack */
  .work-grid { grid-template-columns: 1fr; gap: 20px; }
  .work-iframe-overlay { opacity: 1; } /* always show on touch */
  .work-cover-overlay { background: linear-gradient(180deg, transparent 30%, rgba(0,0,0,.5) 100%); }

  /* Results */
  .results-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .results-bar { padding: 40px 0; }
  .result-number { font-size: 2rem; }
  .result-item::after { display: none; }

  /* Process: vertical timeline with cards */
  .process-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .process-card {
    text-align: left;
    display: flex;
    align-items: flex-start;
    gap: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
  }
  .process-num {
    margin-bottom: 0;
    width: 44px; height: 44px;
    font-size: 1rem;
    flex-shrink: 0;
  }
  .process-card h3 { font-size: 1rem; margin-bottom: 4px; }
  .process-card p { font-size: .84rem; }

  /* Testimonials: horizontal scroll */
  .testimonials-grid {
    grid-template-columns: none;
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 16px;
    padding-bottom: 8px;
    margin: 0 -24px;
    padding-left: 24px;
    padding-right: 24px;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .testimonials-grid::-webkit-scrollbar { display: none; }
  .testimonial-card {
    min-width: 280px;
    max-width: 320px;
    flex-shrink: 0;
    scroll-snap-align: start;
  }

  .industry-list { gap: 16px; }

  .hero-buttons { flex-direction: column; align-items: center; gap: 10px; }
  .btn { padding: 14px 28px; font-size: .9rem; }

  .trust-row {
    flex-direction: column;
    gap: 10px;
    margin-top: 28px;
    padding-top: 20px;
  }

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

  .footer-inner,
  .footer-bottom {
    flex-direction: column;
    gap: 16px;
    text-align: center;
  }
  .footer-top {
    grid-template-columns: 1fr;
    gap: 32px;
    text-align: center;
  }
  .footer-brand p { max-width: none; }

  .cta-inner h2 { font-size: 1.5rem; }
  .cta-trust { flex-direction: column; gap: 8px; }

  .contact-info h2 { font-size: 1.5rem; }
  .contact-form-card { padding: 24px 20px; }
}
