/* Practical final mobile responsiveness: readable cards, even spacing, horizontal slides for dense content. */
@media (max-width: 760px) {
  :root {
    --mobile-pad: clamp(14px, 4vw, 18px);
    --mobile-gap: 12px;
  }

  body {
    background: #fff !important;
    overflow-x: hidden;
  }

  .site-shell {
    width: 100% !important;
    max-width: 480px !important;
    margin: 0 auto !important;
    padding: 14px var(--mobile-pad) 82px !important;
    overflow-x: hidden !important;
  }

  .app-header {
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) auto !important;
    gap: 10px !important;
    align-items: center !important;
    padding: 6px 0 14px !important;
  }

  .brand-logo {
    width: clamp(150px, 45vw, 190px) !important;
    height: auto !important;
  }

  .header-actions {
    gap: 8px !important;
  }

  .icon-btn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    border-radius: 12px !important;
  }

  .quote-btn {
    width: auto !important;
    min-width: 102px !important;
    height: 44px !important;
    padding: 0 14px !important;
    border-radius: 12px !important;
    font-size: 13px !important;
  }

  .hero {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 12px 0 18px !important;
  }

  .hero-copy {
    min-width: 0 !important;
  }

  .hero-copy h1,
  .home-hero .hero-copy h1 {
    max-width: 360px !important;
    font-size: clamp(29px, 8.6vw, 38px) !important;
    line-height: 1.12 !important;
    margin-bottom: 12px !important;
  }

  .hero-copy p {
    max-width: 330px !important;
    font-size: clamp(13px, 3.6vw, 15px) !important;
    line-height: 1.58 !important;
    margin-bottom: 14px !important;
  }

  .hero-art,
  .home-hero .hero-art {
    width: 100% !important;
    max-width: 360px !important;
    max-height: 240px !important;
    margin: -4px auto 0 !important;
    object-fit: contain !important;
  }

  .gradient-btn,
  .light-btn {
    min-height: 44px !important;
    padding: 0 18px !important;
    border-radius: 12px !important;
    font-size: 13px !important;
  }

  .mini-proof {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 18px !important;
  }

  .section {
    padding: 18px 0 !important;
  }

  .section h2 {
    font-size: clamp(22px, 6vw, 28px) !important;
    line-height: 1.18 !important;
    margin-bottom: 14px !important;
  }

  .eyebrow {
    font-size: 11px !important;
    margin-bottom: 6px !important;
  }

  .category-row,
  .plan-grid,
  .portfolio-grid,
  .timeline,
  .filter-tabs {
    display: flex !important;
    gap: var(--mobile-gap) !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 4px 2px 12px !important;
    scrollbar-width: none !important;
  }

  .category-row::-webkit-scrollbar,
  .plan-grid::-webkit-scrollbar,
  .portfolio-grid::-webkit-scrollbar,
  .timeline::-webkit-scrollbar,
  .filter-tabs::-webkit-scrollbar {
    display: none;
  }

  .solution-card,
  .plan-card,
  .project-card,
  .timeline > div {
    flex: 0 0 auto !important;
    scroll-snap-align: start !important;
  }

  .solution-card {
    width: 142px !important;
    min-height: 210px !important;
    padding: 16px 12px !important;
    border-radius: 14px !important;
  }

  .card-icon {
    font-size: 42px !important;
    margin-bottom: 12px !important;
  }

  .solution-card h3,
  .benefit-grid h3,
  .timeline h3,
  .plan-card h3,
  .project-card h3 {
    font-size: 15px !important;
    line-height: 1.2 !important;
    margin-bottom: 7px !important;
  }

  .solution-card p,
  .benefit-grid p,
  .timeline p,
  .plan-card p,
  .project-card p {
    font-size: 12px !important;
    line-height: 1.45 !important;
  }

  .solution-card a,
  .plan-card a {
    height: 40px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
    border-radius: 10px !important;
  }

  .benefit-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: var(--mobile-gap) !important;
  }

  .benefit-grid > div {
    padding: 18px 12px !important;
    border-radius: 14px !important;
  }

  .benefit-grid b {
    width: 56px !important;
    height: 56px !important;
    font-size: 28px !important;
  }

  .timeline > div {
    width: 132px !important;
    text-align: center !important;
  }

  .timeline span {
    width: 54px !important;
    height: 54px !important;
    font-size: 12px !important;
  }

  .feature-strip,
  .stats-dock {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0 !important;
    border-radius: 14px !important;
  }

  .feature-strip div {
    padding: 14px 10px !important;
    font-size: 12px !important;
    line-height: 1.35 !important;
  }

  .section-head {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    align-items: start !important;
  }

  .section-head h2 {
    text-align: left !important;
  }

  .toggle {
    width: max-content !important;
  }

  .plan-card {
    width: min(310px, calc(100vw - 44px)) !important;
    padding: 20px 16px !important;
    border-radius: 16px !important;
  }

  .plan-card li {
    font-size: 12px !important;
    margin: 8px 0 !important;
  }

  .price {
    font-size: 22px !important;
  }

  .monthly-note,
  .price small {
    font-size: 12px !important;
  }

  .project-card {
    width: min(300px, calc(100vw - 44px)) !important;
    padding: 14px !important;
    border-radius: 16px !important;
  }

  .project-card span,
  .project-card a {
    font-size: 12px !important;
  }

  .cta-band {
    display: grid !important;
    grid-template-columns: 96px 1fr !important;
    gap: 12px !important;
    padding: 16px !important;
    border-radius: 16px !important;
  }

  .cta-band img {
    width: 96px !important;
  }

  .cta-band h2 {
    font-size: 18px !important;
    line-height: 1.22 !important;
  }

  .cta-band p,
  .cta-band li {
    font-size: 12px !important;
  }

  .cta-band ul {
    grid-column: 1 / -1 !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 4px 10px !important;
  }

  .stats-dock {
    margin: 16px 0 10px !important;
  }

  .stats-dock div {
    padding: 14px 10px !important;
  }

  .stat-icon {
    font-size: 26px !important;
  }

  .stats-dock strong {
    font-size: 18px !important;
  }

  .stats-dock small {
    font-size: 11px !important;
  }

  .client-strip {
    display: flex !important;
    gap: 10px !important;
    overflow-x: auto !important;
    padding: 12px !important;
    border-radius: 14px !important;
    scrollbar-width: none !important;
  }

  .client-strip::-webkit-scrollbar {
    display: none;
  }

  .client-strip strong,
  .client-strip span {
    flex: 0 0 auto !important;
    min-width: 110px !important;
    padding: 8px !important;
    font-size: 12px !important;
  }

  .contact-grid,
  .case-study {
    grid-template-columns: 1fr !important;
  }

  .bottom-nav {
    width: 100% !important;
    max-width: 480px !important;
    height: 68px !important;
    border-radius: 18px 18px 0 0 !important;
  }

  .bottom-nav a {
    font-size: 21px !important;
  }

  .bottom-nav span {
    font-size: 10px !important;
  }

  .bottom-nav .chat-fab {
    width: 56px !important;
    height: 56px !important;
    margin-top: -28px !important;
  }
}

@media (max-width: 390px) {
  .site-shell {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }

  .app-header {
    grid-template-columns: 42px minmax(0, 1fr) 44px !important;
  }

  .quote-btn {
    display: none !important;
  }

  .brand-logo {
    width: 166px !important;
  }

  .hero-copy h1,
  .home-hero .hero-copy h1 {
    font-size: 30px !important;
  }
}
