/**
 * Sobratema — melhorias mobile e UX (sem alterar identidade visual)
 * Complementa style.css; carregado em páginas públicas.
 */

/* Evita scroll horizontal indevido */
html {
  overflow-x: clip;
}

body.nav-menu-open {
  overflow: hidden;
  touch-action: none;
}

body.nav-menu-open .mainnav.is-open {
  touch-action: pan-y;
}

/* Foco visível (teclado) — não altera layout */
:focus {
  outline: none;
}

:focus-visible {
  outline: 3px solid var(--sb-red);
  outline-offset: 2px;
}

.btn:focus-visible,
.nav-link:focus-visible,
.nav-toggle:focus-visible,
.social a:focus-visible,
.quick-item:focus-visible,
.site-footer ul a:focus-visible {
  outline-offset: 3px;
}

/* Áreas de toque confortáveis */
@media (max-width: 768px) {
  .btn {
    min-height: 44px;
    padding: 12px 18px;
  }

  .nav-toggle {
    min-width: 48px;
    min-height: 48px;
    flex-shrink: 0;
  }

  .nav-link,
  .mainnav a.nav-link,
  .mainnav button.nav-link {
    min-height: 48px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .nav-submenu a {
    min-height: 44px;
    display: flex;
    align-items: center;
    padding: 12px 20px 12px 28px;
  }

  .social a {
    width: 44px;
    height: 44px;
  }

  .site-footer ul a {
    display: inline-block;
    padding: 4px 0;
    min-height: 32px;
    line-height: 1.5;
  }

  /* Menu mobile: rolagem interna e não cobrir tela inteira sem scroll */
  .mainnav.is-open {
    max-height: min(75vh, calc(100dvh - 88px));
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }

  .mainnav.is-open .mainnav-inner {
    padding-bottom: env(safe-area-inset-bottom, 0);
  }

  /* Header: logo e CTAs não espremem */
  .header-inner {
    align-items: center;
  }

  .logo-img {
    max-width: min(200px, 48vw);
  }

  .header-btns {
    flex-wrap: nowrap;
    gap: 8px;
  }

  .header-btns .btn-primary {
    padding-left: 16px;
    padding-right: 16px;
  }

  /* Formulários: evita zoom automático no iOS e facilita toque */
  input:not([type='checkbox']):not([type='radio']):not([type='hidden']),
  select,
  textarea {
    font-size: max(16px, 1rem);
    min-height: 44px;
  }

  textarea {
    min-height: 120px;
  }

  .site-busca-input {
    font-size: 16px;
    min-height: 44px;
  }

  /* Rodapé: blocos empilhados com respiro */
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
    gap: 12px;
  }

  .footer-brand p {
    font-size: 16px;
    line-height: 1.65;
  }
}

@media (max-width: 480px) {
  .header-inner {
    padding: 14px 0;
  }

  .header-btns .btn-outline {
    padding: 12px 14px;
  }

  .header-btns .btn-outline i {
    margin-right: 0;
  }

  .slide-btns {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
  }

  .quick-item {
    min-height: 120px;
    padding: 20px 12px;
  }

  .quick-item span {
    font-size: 11px;
  }
}

/* Tablet: menu horizontal com rolagem se não couber */
@media (min-width: 769px) and (max-width: 1100px) {
  .mainnav-inner {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .mainnav-inner::-webkit-scrollbar {
    height: 6px;
  }

  .mainnav-inner::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.25);
    border-radius: 3px;
  }
}

/* Tabelas largas: scroll horizontal contido */
.ch-table-wrap,
.table-responsive,
.ct-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  max-width: 100%;
}

/* Reduz movimento em hover no touch */
@media (hover: none) {
  .btn:hover {
    transform: none;
  }

  .quick-item:hover {
    transform: none;
  }
}

/* Safe area em elementos fixos comuns */
@supports (padding: max(0px)) {
  @media (max-width: 768px) {
    .ct-modal,
    .as-modal.modal-ficha {
      padding-bottom: max(1rem, env(safe-area-inset-bottom));
    }
  }
}
