/* ========================================
   PÁGINAS LEGAIS · privacidade · termos · reembolso
   Stylesheet auto-contido. Reutiliza as CSS vars de ../styles.css
   quando presentes, com fallback inline para o caso de o styles.css
   da produção ainda não estar atualizado.
   ======================================== */

.legal-hero {
  padding: 140px 0 40px;
  background: linear-gradient(180deg, var(--bg-alt, #F5F7FA) 0%, transparent 100%);
}

[data-theme="dark"] .legal-hero {
  background: linear-gradient(180deg, rgba(20, 195, 154, 0.04) 0%, transparent 100%);
}

.legal-hero .container--narrow { max-width: 820px; }

.legal-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.875rem;
  color: var(--text-muted, #6B7A90);
  margin-bottom: 20px;
}

.legal-breadcrumb a {
  color: var(--text-muted, #6B7A90);
  text-decoration: none;
  transition: color 0.2s ease;
}

.legal-breadcrumb a:hover { color: var(--teal, #14C39A); }

.legal-meta {
  font-size: 0.875rem;
  color: var(--text-muted, #6B7A90);
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--line, #E3E8F0);
}

[data-theme="dark"] .legal-meta { border-top-color: rgba(255, 255, 255, 0.08); }

.legal-prose {
  max-width: 820px;
  font-size: 1rem;
  line-height: 1.7;
  color: var(--text, #0B1F3A);
}

[data-theme="dark"] .legal-prose { color: #E8EDF5; }

.legal-prose p,
.legal-prose ul,
.legal-prose ol {
  margin: 0 0 18px;
}

.legal-prose ul,
.legal-prose ol {
  padding-left: 24px;
}

.legal-prose li {
  margin-bottom: 8px;
}

.legal-prose strong {
  color: var(--text, #0B1F3A);
  font-weight: 600;
}

[data-theme="dark"] .legal-prose strong { color: #FFFFFF; }

.legal-prose em { font-style: italic; }

.legal-prose a {
  color: var(--teal-dark, #0F8F71);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
}

[data-theme="dark"] .legal-prose a { color: var(--teal-soft, #2BDFB3); }

.legal-prose a:hover { color: var(--teal, #14C39A); }

.legal-section {
  padding: 28px 0;
  border-bottom: 1px solid var(--line, #E3E8F0);
}

[data-theme="dark"] .legal-section { border-bottom-color: rgba(255, 255, 255, 0.08); }

.legal-section:last-of-type { border-bottom: none; }

.legal-section h2 {
  font-family: var(--font-display, 'Fraunces', Georgia, serif);
  font-size: clamp(1.375rem, 2.4vw, 1.75rem);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.015em;
  margin: 0 0 16px;
  color: var(--text, #0B1F3A);
}

[data-theme="dark"] .legal-section h2 { color: #FFFFFF; }

.legal-section h3 {
  font-family: var(--font-body, 'Inter', system-ui, sans-serif);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  margin: 22px 0 12px;
  color: var(--text, #0B1F3A);
}

[data-theme="dark"] .legal-section h3 { color: #FFFFFF; }

.legal-table-wrap {
  position: relative;
  margin: 16px 0 20px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border: 1px solid var(--line, #E3E8F0);
  border-radius: var(--radius, 14px);
}

/* Indicador visual de scroll em mobile */
.legal-table-wrap::after {
  content: '← deslize horizontalmente →';
  display: block;
  font-size: 0.75rem;
  color: var(--text-muted, #6B7A90);
  text-align: center;
  padding: 6px 8px;
  border-top: 1px dashed var(--line, #E3E8F0);
  font-style: italic;
}

@media (min-width: 768px) {
  .legal-table-wrap::after { display: none; }
}

[data-theme="dark"] .legal-table-wrap { border-color: rgba(255, 255, 255, 0.08); }

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
  background: var(--bg-card, #FFFFFF);
}

[data-theme="dark"] .legal-table { background: #122E54; }

.legal-table thead {
  background: rgba(20, 195, 154, 0.08);
}

.legal-table th,
.legal-table td {
  padding: 12px 14px;
  text-align: left;
  vertical-align: top;
  border-bottom: 1px solid var(--line, #E3E8F0);
}

[data-theme="dark"] .legal-table th,
[data-theme="dark"] .legal-table td { border-bottom-color: rgba(255, 255, 255, 0.08); }

.legal-table th {
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--teal-dark, #0F8F71);
}

[data-theme="dark"] .legal-table th { color: var(--teal-soft, #2BDFB3); }

.legal-table tr:last-child td { border-bottom: none; }

.legal-callout {
  margin: 16px 0;
  padding: 14px 18px;
  background: rgba(20, 195, 154, 0.06);
  border-left: 3px solid var(--teal, #14C39A);
  border-radius: 0 var(--radius, 14px) var(--radius, 14px) 0;
  font-size: 0.9375rem;
  color: var(--text-muted, #6B7A90);
}

[data-theme="dark"] .legal-callout { color: #97A6BD; }

.legal-cta {
  margin: 48px 0 0;
  padding: 24px 28px;
  background: linear-gradient(135deg, rgba(20, 195, 154, 0.08), rgba(20, 195, 154, 0.02));
  border: 1px solid rgba(20, 195, 154, 0.25);
  border-radius: var(--radius-lg, 22px);
  text-align: center;
}

.legal-cta p { margin: 0 0 8px; font-size: 0.9375rem; }
.legal-cta p:last-child { margin: 0; }

/* Defaults mobile-first */
.legal-hero { padding: 110px 0 24px; }
.legal-prose { font-size: 0.9375rem; }
.legal-table { font-size: 0.875rem; }
.legal-table th,
.legal-table td { padding: 10px 12px; }
.legal-cta { padding: 20px 18px; }

@media (min-width: 768px) {
  .legal-hero { padding: 140px 0 40px; }
  .legal-prose { font-size: 1rem; }
  .legal-table { font-size: 0.9375rem; }
  .legal-table th,
  .legal-table td { padding: 12px 14px; }
  .legal-cta { padding: 24px 28px; }
}
