/* SoftAcesso - Mobile Responsive v3 */
/* No global rules - everything inside media queries to not break desktop menu */

@media (max-width: 768px) {

  #conteudo-principal { overflow-x: hidden; }

  .hero-banner { padding: 1rem 0 0.5rem; }
  .hero-banner h1 {
    font-size: 1.4rem;
    padding: 0 12px;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
  }
  .hero-banner .hero-sub {
    font-size: 0.88rem;
    padding: 0 12px;
    line-height: 1.5;
  }
  .hero-banner .hero-badges {
    gap: 6px;
    padding: 0 8px;
  }
  .hero-banner .badge {
    padding: 4px 10px;
    font-size: 0.68rem;
  }

  .hero-cta {
    flex-direction: column;
    align-items: stretch;
    padding: 0 12px;
    gap: 10px;
  }
  .hero-cta .btn-download,
  .hero-cta .btn-secondary {
    width: 100%;
    text-align: center;
    box-sizing: border-box;
    display: block;
    font-size: 0.95rem;
    padding: 13px 16px;
  }

  .hero-screenshot {
    margin: 1.2rem 8px;
    padding: 0;
  }

  .stats-bar {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px;
    padding: 0 8px;
    margin: 1.5rem 0;
  }
  .stat {
    padding: 12px 8px;
    min-width: unset !important;
  }
  .stat .num { font-size: 1.3rem; }
  .stat .label { font-size: 0.68rem; }

  .comparison-table { display: none; }

  .product-features { margin: 1.5rem 0; padding: 0 4px; }
  .features-title { font-size: 1.15rem !important; padding: 0 8px; }
  .features-item { padding: 10px 12px !important; }
  .features-text { font-size: 0.82rem; }
  .features-text strong { display: block; margin-bottom: 2px; }

  .how-it-works { margin: 1.5rem 0; padding: 0 8px; }
  .how-it-works h2 { font-size: 1.15rem; }
  .step { padding: 12px; gap: 10px; }
  .step-num { width: 28px; height: 28px; font-size: 0.8rem; }
  .step-text h4 { font-size: 0.88rem; }
  .step-text p { font-size: 0.8rem; }

  .trust-section { padding: 1.2rem 8px !important; margin: 1.5rem 0 !important; }
  .trust-section h3 { font-size: 1.15rem !important; }
  .trust-items { grid-template-columns: 1fr 1fr !important; gap: 8px !important; }
  .trust-item { padding: 14px 10px !important; }
  .trust-item h4 { font-size: 0.88rem !important; }
  .trust-item p { font-size: 0.75rem !important; line-height: 1.4 !important; }
  .trust-icon { width: 20px !important; height: 20px !important; }

  .faq-section { margin: 1.5rem 0; padding: 0 8px; }
  .faq-section h2 { font-size: 1.15rem; }
  .faq-item { padding: 12px 0; }
  .faq-item summary { font-size: 0.88rem; gap: 8px; }
  .faq-item .faq-answer { font-size: 0.8rem; line-height: 1.5; }

  .final-cta {
    padding: 1.2rem 12px;
    margin: 1.5rem 8px;
    border-radius: 12px;
  }
  .final-cta h2 { font-size: 1.15rem; }
  .final-cta p { font-size: 0.82rem; margin-bottom: 1rem; }
  .final-cta .btn-download {
    width: 100%;
    box-sizing: border-box;
    font-size: 0.92rem;
    padding: 12px 16px;
  }
}

@media (max-width: 420px) {
  .hero-banner h1 { font-size: 1.2rem; }
  .hero-banner .hero-sub { font-size: 0.82rem; }
  .hero-banner .badge { font-size: 0.6rem; padding: 3px 7px; }

  .stat .num { font-size: 1.1rem; }
  .stat .label { font-size: 0.6rem; }
  .stat { padding: 10px 6px; }

  .step {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 6px;
  }

  .trust-items { grid-template-columns: 1fr !important; }

  .features-text { font-size: 0.78rem; }
  .faq-item summary { font-size: 0.82rem; }
  .faq-item .faq-answer { font-size: 0.76rem; }
}
