
    /* ── Cabeçalho da página ── */
    .legal-hero {
      background: linear-gradient(135deg, #0047ab 0%, #0069d9 100%);
      padding: 120px 0 60px;         /* 120px no topo para não colidir com a navbar fixa */
      color: #fff;
      text-align: center;
    }
    .legal-hero .legal-badge {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: rgba(255,255,255,0.15);
      border: 1px solid rgba(255,255,255,0.25);
      color: #fff;
      font-size: 13px;
      font-weight: 600;
      padding: 6px 14px;
      border-radius: 50px;
      margin-bottom: 20px;
    }
    .legal-hero h1 {
      font-family: 'Fraunces', serif;
      font-size: clamp(2rem, 4vw, 2.8rem);
      font-weight: 700;
      margin-bottom: 12px;
    }
    .legal-hero p {
      font-size: 15px;
      opacity: .8;
      max-width: 520px;
      margin: 0 auto;
    }

    /* ── Layout principal ── */
    .legal-layout {
      display: grid;
      grid-template-columns: 240px 1fr;  /* sumário fixo + conteúdo */
      gap: 48px;
      max-width: 1100px;
      margin: 0 auto;
      padding: 60px 24px 80px;
      align-items: start;
    }
    @media (max-width: 900px) {
      /* Em telas menores, sumário some e conteúdo ocupa tudo */
      .legal-layout { grid-template-columns: 1fr; }
      .legal-toc    { display: none; }
    }

    /* ── Sumário lateral (Table of Contents) ── */
    .legal-toc {
      position: sticky;
      top: 88px;                  /* abaixo da navbar fixa */
      background: #f8faff;
      border: 1px solid #e2eaf8;
      border-radius: 14px;
      padding: 20px 18px;
    }
    .legal-toc h6 {
      font-size: 11px;
      font-weight: 700;
      letter-spacing: .08em;
      text-transform: uppercase;
      color: #94a3b8;
      margin-bottom: 12px;
    }
    .legal-toc a {
      display: block;
      font-size: 13px;
      color: #475569;
      text-decoration: none;
      padding: 5px 8px;
      border-radius: 6px;
      transition: background .15s, color .15s;
      line-height: 1.4;
    }
    .legal-toc a:hover,
    .legal-toc a.active {
      background: #e8f0fe;
      color: #0047ab;
      font-weight: 600;
    }

    /* ── Corpo do documento ── */
    .legal-body {
      min-width: 0;               /* evita overflow em grid */
    }

    /* Metadados (versão, data, download) */
    .legal-meta {
      display: flex;
      align-items: center;
      gap: 24px;
      background: #f8faff;
      border: 1px solid #e2eaf8;
      border-radius: 12px;
      padding: 16px 20px;
      margin-bottom: 40px;
      flex-wrap: wrap;
    }
    .legal-meta-item {
      display: flex;
      align-items: center;
      gap: 7px;
      font-size: 13px;
      color: #64748b;
    }
    .legal-meta-item i { color: #0047ab; font-size: 15px; }
    .legal-meta .btn-download {
      margin-left: auto;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: #0047ab;
      color: #fff;
      border: none;
      border-radius: 8px;
      padding: 8px 16px;
      font-size: 13px;
      font-weight: 600;
      text-decoration: none;
      transition: background .2s;
    }
    .legal-meta .btn-download:hover { background: #0069d9; color: #fff; }

    /* Seções */
    .legal-section {
      margin-bottom: 44px;
      scroll-margin-top: 96px;    /* offset para links âncora com navbar fixa */
    }
    .legal-section-title {
      display: flex;
      align-items: center;
      gap: 12px;
      font-size: 1.15rem;
      font-weight: 700;
      color: #0047ab;
      margin-bottom: 14px;
      padding-bottom: 10px;
      border-bottom: 2px solid #e2eaf8;
    }
    .legal-section-title .sec-num {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 30px;
      height: 30px;
      background: #e8f0fe;
      color: #0047ab;
      border-radius: 50%;
      font-size: 13px;
      font-weight: 700;
      flex-shrink: 0;
    }
    .legal-section p {
      font-size: 14.5px;
      color: #374151;
      line-height: 1.75;
      margin-bottom: 10px;
    }

    /* Subseções */
    .legal-subsection {
      margin: 18px 0 12px;
    }
    .legal-subsection-title {
      font-size: 14px;
      font-weight: 700;
      color: #1e40af;
      margin-bottom: 8px;
    }

    /* Listas */
    .legal-list {
      list-style: none;
      padding: 0;
      margin: 0 0 10px;
    }
    .legal-list li {
      display: flex;
      align-items: flex-start;
      gap: 9px;
      font-size: 14px;
      color: #374151;
      line-height: 1.65;
      padding: 5px 0;
      border-bottom: 1px solid #f1f5f9;
    }
    .legal-list li:last-child { border-bottom: none; }
    .legal-list li i {
      color: #0d9488;
      font-size: 13px;
      margin-top: 3px;
      flex-shrink: 0;
    }

    /* Destaque (caixa de aviso) */
    .legal-highlight {
      background: #eff6ff;
      border-left: 4px solid #0047ab;
      border-radius: 0 10px 10px 0;
      padding: 14px 18px;
      margin: 14px 0;
      font-size: 14px;
      color: #1e3a8a;
      line-height: 1.65;
    }
    .legal-highlight i { margin-right: 6px; }

    /* Separador entre seções */
    .legal-divider {
      border: none;
      border-top: 1px solid #e2eaf8;
      margin: 40px 0;
    }

    /* ── Rodapé de navegação (anterior / próxima) ── */
    .legal-nav-bottom {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 24px 0 0;
      border-top: 1px solid #e2eaf8;
      gap: 12px;
      flex-wrap: wrap;
    }
    .legal-nav-bottom a {
      display: inline-flex;
      align-items: center;
      gap: 7px;
      font-size: 14px;
      font-weight: 600;
      color: #0047ab;
      text-decoration: none;
      padding: 10px 18px;
      border: 1.5px solid #cbd5e1;
      border-radius: 8px;
      transition: border-color .2s, background .2s;
    }
    .legal-nav-bottom a:hover {
      border-color: #0047ab;
      background: #f0f5ff;
    }
    .legal-nav-bottom a.primary {
      background: #0047ab;
      color: #fff;
      border-color: #0047ab;
    }
    .legal-nav-bottom a.primary:hover { background: #0069d9; border-color: #0069d9; }