/* Tablet (1024px and below) */
@media (max-width: 1024px) {
  .container { padding: 0 1.5rem; }
  section { padding: 6rem 0; }
  .nav { padding: 0 1.5rem; }
  nav ul { gap: 1.5rem; }
  nav ul a { font-size: 0.75rem; }
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-image { display: none; }
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr; gap: 2.5rem; }
  .footer-col:nth-child(4) { display: none; }

  /* Hero vira coluna: tagline volta pro fluxo (era flex-item solto à direita) */
  .hero {
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    min-height: auto;
    padding: 7rem 0 3.5rem;
  }
  .hero-tagline {
    position: static;
    margin-top: 3rem;
    left: auto;
    right: auto;
    bottom: auto;
  }
}

/* Hamburger aparece (1024px e abaixo): nav de 7 itens só cabe acima disso */
@media (max-width: 1024px) {
  .nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .nav-toggle {
    display: flex;
    margin-left: auto;
  }
  .nav-menu {
    position: fixed;
    top: 0; right: -100%;
    width: min(380px, 85vw);
    height: 100vh;
    background: var(--cream);
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    padding: 6rem 2.5rem 2rem;
    gap: 2rem;
    box-shadow: -10px 0 30px rgba(0, 0, 0, 0.1);
    transition: right 0.35s ease;
    overflow-y: auto;
  }
  .nav-menu.active { right: 0; }
  nav ul {
    flex-direction: column;
    gap: 1.5rem;
    width: 100%;
  }
  nav ul a {
    font-size: 1rem;
    letter-spacing: 0.15em;
    /* área de toque maior no menu off-canvas (alvo ~44px) */
    padding: 0.7rem 0;
  }
  nav ul a::after { display: none; }
  .nav-menu .cta-btn {
    width: 100%;
    text-align: center;
    margin-top: 1rem;
  }
  .nav-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(4px);
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s;
    z-index: 99;
  }
  .nav-overlay.active { opacity: 1; visibility: visible; }
}

/* Mobile small (768px and below) */
@media (max-width: 768px) {
  .logo img { height: 68px; }
  .logo-wordmark strong { font-size: 1.35rem; }
  .logo-wordmark span { font-size: 0.64rem; letter-spacing: 0.38em; }
  section { padding: 4.5rem 0; }
  .about-grid { grid-template-columns: 1fr; gap: 3rem; }
  .about-stats { gap: 1rem; }
  .stat { flex: 0 1 calc(50% - 0.5rem); padding: 1.25rem; }
  .stat-number { font-size: 2.25rem; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .footer-col:nth-child(4) { display: block; }
  .hero { padding: 6rem 0 3rem; }
  .hero h1 { font-size: clamp(2rem, 8vw, 3rem); }
  .hero p { font-size: 1rem; }
  .hero-actions { flex-direction: column; align-items: stretch; width: 100%; max-width: 320px; margin-left: auto; margin-right: auto; }
  .hero-actions .cta-btn { text-align: center; }
  .hero-tagline { margin-top: 2.5rem; font-size: 0.65rem; letter-spacing: 0.3em; }
  .services-grid { gap: 1rem; }
  .service-card { flex-basis: 100%; max-width: none; padding: 2rem 1.5rem; }
  .materials-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .material { padding: 1.75rem 1rem; }
  .clients-logos { gap: 1.5rem 1rem; }
  .client-logo { flex-basis: 40%; max-width: none; padding: 1.25rem 0.75rem; }
  .client-logo img { max-height: 46px; max-width: 130px; }
  .section-lead { margin-bottom: 2.5rem; }
  .social-float { bottom: 1.5rem; right: 1.5rem; gap: 0.65rem; }
  .social-float a { width: 52px; height: 52px; }
  .social-float svg { width: 26px; height: 26px; }
  .gallery-grid { column-count: 2; column-gap: 1rem; }
  .gallery-item { margin-bottom: 1rem; }
  /* Legenda compacta no mobile: fonte e faixa menores para a foto aparecer mais
     (um toque já abre o lightbox, então "revelar no toque" não cabe aqui). */
  .gallery-cap { opacity: 1; transform: none; padding: 1.1rem 0.7rem 0.55rem; font-size: 0.66rem; }
  .gallery-cap strong { font-size: 0.9rem; margin-bottom: 0; }
  .stone-cap { padding: 1rem 0.65rem 0.55rem; font-size: 0.58rem; letter-spacing: 0.1em; }
  .stone-cap strong { font-size: 0.88rem; }
  .hero-regions { font-size: 0.78rem; margin-top: 1.5rem; }
  .faq-item summary { font-size: 1.25rem; padding-left: 2.5rem; padding-right: 2.5rem; }
  .faq-answer { padding-left: 0; padding-right: 0; }
  /* Mobile: sem botões (X e setas, que ficavam feios). Imagem centralizada;
     tocar fora fecha; swipe navega. Chevrons fantasma nas bordas + um nudge
     ao abrir ensinam o gesto de arrastar, sem poluir. */
  .lightbox { padding: 1.5rem 0.75rem; align-items: center; }
  .lightbox-fig img { max-height: 78vh; }
  .lightbox-close,
  .lightbox-nav { display: none; }

  .lightbox::before,
  .lightbox::after {
    position: absolute;
    top: 50%;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 2.1rem;
    line-height: 1;
    color: rgba(245, 242, 238, 0.45);
    text-shadow: 0 1px 8px rgba(0, 0, 0, 0.55);
    pointer-events: none;
    z-index: 5;
  }
  .lightbox::before { content: '\2039'; left: 0.5rem; animation: lbHintL 2.4s ease-in-out infinite; }
  .lightbox::after { content: '\203A'; right: 0.5rem; animation: lbHintR 2.4s ease-in-out infinite; }

  @keyframes lbHintL {
    0%, 100% { transform: translateY(-50%) translateX(0); opacity: 0.3; }
    50% { transform: translateY(-50%) translateX(-4px); opacity: 0.6; }
  }
  @keyframes lbHintR {
    0%, 100% { transform: translateY(-50%) translateX(0); opacity: 0.3; }
    50% { transform: translateY(-50%) translateX(4px); opacity: 0.6; }
  }
  .testimonial { width: min(82vw, 320px); }
  .testimonial blockquote { font-size: 1.2rem; }
}

/* Mobile extra small (480px and below) */
@media (max-width: 480px) {
  .nav { padding: 0 1rem; }
  .container { padding: 0 1.25rem; }
  .logo img { height: 52px; }
  .logo { gap: 0.55rem; }
  /* Nome sempre visível no mobile, dimensionado para caber ao lado do símbolo e do menu */
  .logo-wordmark strong { font-size: 1.05rem; letter-spacing: 0.1em; }
  .logo-wordmark span { font-size: 0.54rem; letter-spacing: 0.3em; }
  .footer-grid { grid-template-columns: 1fr; }
  .about-stats .stat { flex: 0 1 100%; }
  /* rótulos de materiais em 2 colunas; última linha ímpar centraliza (flex + justify-center) */
  .materials-grid { gap: 1.75rem 1rem; }
  .material { flex: 0 1 calc(50% - 1rem); }
  .clients-logos { gap: 1.25rem 0.75rem; }
  .client-logo img { max-height: 40px; max-width: 120px; }
  .hero-eyebrow { font-size: 0.7rem; letter-spacing: 0.2em; }
  .section-eyebrow { font-size: 0.7rem; letter-spacing: 0.2em; }
  .footer-bottom { flex-direction: column; text-align: center; }
  /* Fotos em 2 colunas no celular (menores), em vez de 1 coluna que estica a rolagem.
     Toque na imagem abre inteira no lightbox. */
  .gallery-grid { column-count: 2; column-gap: 0.75rem; }
  .gallery-item { margin-bottom: 0.75rem; }
  /* chapas em 2 colunas; flex-grow 0 + justify-center fazem a última linha ímpar centralizar */
  .stone-grid { gap: 0.75rem; }
  .stone-item { flex: 0 1 calc(50% - 0.5rem); max-width: none; }
  .faq-cta { flex-direction: column; align-items: center; }
}

/* Sem movimento: chevrons-fantasma do lightbox ficam estáticos (o nudge também não roda) */
@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
  .lightbox::before,
  .lightbox::after { animation: none; }
}
