/* ============================================================
   Acessibilidade global · Área de Membros
   Carregado em todas as páginas (/assets/a11y.css).
   Foco visível por teclado, respeito a "reduzir movimento",
   utilitários para leitores de tela, skip-link e alvos de toque.
   Tudo aditivo — não altera o visual para usuários de mouse.
   ============================================================ */

/* 1) Foco visível por TECLADO (não aparece no clique de mouse). -------- */
:where(a, button, input, select, textarea, summary, [tabindex], [role="button"],
       [role="tab"], [role="link"], [role="menuitem"], [role="checkbox"],
       [role="switch"])
  :focus-visible,
:focus-visible {
  outline: 3px solid #ff5db1 !important;
  outline-offset: 2px !important;
  border-radius: 6px;
}
/* Mantém o anel só no teclado: remove no foco vindo de mouse/toque. */
:where(a, button, input, select, textarea, [tabindex], [role="button"])
  :focus:not(:focus-visible) { outline: none; }

/* 2) Conteúdo apenas para leitores de tela. --------------------------- */
.sr-only {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.sr-only.focusable:focus,
.sr-only.focusable:focus-visible {
  position: fixed !important;
  top: 12px; left: 12px;
  width: auto; height: auto;
  padding: 12px 18px; margin: 0;
  clip: auto; white-space: normal;
}

/* 3) Skip-link ("pular para o conteúdo") — visível só quando focado. --- */
.skip-link {
  position: fixed;
  top: -120px; left: 12px;
  z-index: 2147483647;
  padding: 12px 18px;
  background: #e62389; color: #fff;
  font: 700 14px/1 'Montserrat', system-ui, -apple-system, sans-serif;
  border-radius: 10px;
  text-decoration: none;
  box-shadow: 0 12px 30px rgba(0, 0, 0, .55);
  transition: top .18s ease;
}
.skip-link:focus { top: 12px; outline: 3px solid #fff; outline-offset: 2px; }

/* 4) Respeitar a preferência de "reduzir movimento" do sistema. ------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

/* 5) Alvos de toque confortáveis em telas de toque (só ícones/controles
      pequenos não rotulados ganham área; não distorce o layout denso). - */
@media (pointer: coarse) {
  a[aria-label]:not(:has(*)) ,
  button[aria-label]:empty,
  [role="button"][aria-label]:empty {
    min-width: 44px; min-height: 44px;
  }
}

/* 6) Não ler SVGs decorativos marcados pelo a11y.js. ------------------ */
svg[aria-hidden="true"] { pointer-events: none; }

/* 7) Realce de seleção legível na paleta rosa. ----------------------- */
::selection { background: #e62389; color: #fff; }
