/* ============================================================
   Páginas legais — estilo herdado do style.css principal.
   Apenas variações específicas (tipografia/legibilidade) aqui.
============================================================ */

/* ── Dark base so legal pages match the main site ── */
html, body { background: #04070d !important; }

.legal {
  padding: 130px 0 100px;
  min-height: 80vh;
  position: relative;
  z-index: 1;
}
.legal__back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 28px;
  transition: color .2s;
}
.legal__back:hover { color: var(--cyan); }
.legal__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(40px, 8vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.018em;
  margin: 8px 0 28px;
  color: var(--text);
}
.legal__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-faint);
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  margin-bottom: 36px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
}
.legal__body { max-width: 720px; }
.legal__body h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(24px, 5vw, 32px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--text);
  margin: 40px 0 14px;
}
.legal__body h2:first-child { margin-top: 0; }
.legal__body p {
  font-size: 16px;
  line-height: 1.75;
  color: var(--text-muted);
  margin: 0 0 16px;
}
.legal__body strong { color: var(--text); font-weight: 600; }
.legal__body a {
  color: var(--cyan);
  text-decoration: underline;
  text-decoration-color: rgba(94, 227, 232, .35);
  text-underline-offset: 3px;
  transition: text-decoration-color .2s;
}
.legal__body a:hover { text-decoration-color: var(--cyan); }
.legal__body ul {
  margin: 12px 0 18px;
  padding: 0;
  list-style: none;
}
.legal__body ul li {
  font-size: 15.5px;
  line-height: 1.7;
  color: var(--text-muted);
  padding-left: 22px;
  position: relative;
  margin-bottom: 8px;
}
.legal__body ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 11px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cyan);
  opacity: 0.5;
}


/* PATCH 2026-05-15 · v17 — legal pages mobile rhythm + native scroll */
@media (max-width: 959px) {
  html,
  body {
    min-height: 100% !important;
    height: auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-y: auto !important;
    touch-action: auto !important;
  }

  body.legal-page .bg-canvas,
  body.legal-page .bg-nebula {
    display: none !important;
  }

  .legal {
    min-height: auto !important;
    padding: 86px 0 64px !important;
    overflow: visible !important;
    touch-action: pan-y !important;
  }

  .legal__back {
    margin-bottom: 18px !important;
  }

  .legal__title {
    margin: 10px 0 22px !important;
    font-size: clamp(42px, 13vw, 58px) !important;
  }

  .legal__meta {
    margin-bottom: 28px !important;
    padding-bottom: 18px !important;
    gap: 12px 18px !important;
  }

  .legal__body {
    max-width: 100% !important;
    padding-bottom: 48px !important;
  }
}

@media (max-width: 420px) {
  .legal {
    padding-top: 80px !important;
  }
}

/* PATCH 2026-05-15 · v17 refeita — legal mobile scroll + compact top */
@media (max-width: 959px) {
  html {
    height: auto !important;
    min-height: 100% !important;
    overflow-y: auto !important;
    overflow-x: clip !important;
    overscroll-behavior-y: auto !important;
    touch-action: auto !important;
  }

  body.legal-page,
  body.legal-page.no-overflow,
  body.legal-page.menu-open,
  body.legal-page.is-menu-open,
  body.legal-page.nav-open {
    position: relative !important;
    height: auto !important;
    min-height: 100dvh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch !important;
    transform: none !important;
    -webkit-transform: none !important;
  }

  body.legal-page .bg-stage,
  body.legal-page .bg-stage *,
  body.legal-page .bg-canvas,
  body.legal-page .bg-nebula,
  body.legal-page .bg-grid,
  body.legal-page .bg-vignette {
    pointer-events: none !important;
  }

  body.legal-page .bg-canvas,
  body.legal-page .bg-nebula {
    display: none !important;
  }

  body.legal-page main.legal,
  body.legal-page .legal,
  body.legal-page .legal .container,
  body.legal-page .legal__body {
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    touch-action: pan-y !important;
  }

  body.legal-page .legal {
    min-height: auto !important;
    padding-top: 64px !important;
    padding-bottom: 60px !important;
  }

  body.legal-page .legal__back {
    margin-top: 0 !important;
    margin-bottom: 14px !important;
  }

  body.legal-page .legal__title {
    margin-top: 8px !important;
    margin-bottom: 18px !important;
    font-size: clamp(40px, 12vw, 56px) !important;
  }

  body.legal-page .legal__meta {
    margin-bottom: 24px !important;
    padding-bottom: 14px !important;
    gap: 10px 16px !important;
  }

  body.legal-page .legal__body {
    padding-bottom: 56px !important;
  }
}

@media (max-width: 420px) {
  body.legal-page .legal {
    padding-top: 58px !important;
  }
}
