/* Защита от горизонтального скролла */
  html, body { overflow-x: hidden; max-width: 100vw; }

  .legal-doc {
    color: var(--fg);
    font-size: 1rem;
    line-height: 1.8;
  }

  .legal-doc h1 {
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 700;
    color: var(--fg);
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 2px solid var(--accent);
  }

  .legal-doc .lead-text {
    font-size: 1.05rem;
    color: var(--fg);
    opacity: 0.85;
    margin-bottom: 2rem;
  }

  .legal-doc h2 {
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    font-weight: 700;
    color: var(--accent);
    margin-top: 2.5rem;
    margin-bottom: 0.85rem;
    padding-bottom: 0.4rem;
    border-bottom: 1px solid var(--card-border);
  }

  .legal-doc h3 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--fg);
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    opacity: 0.9;
  }

  .legal-doc p {
    margin-bottom: 1rem;
    color: var(--fg);
    opacity: 0.88;
  }

  .legal-doc ul,
  .legal-doc ol {
    padding-left: 1.5rem;
    margin-bottom: 1.25rem;
    color: var(--fg);
    opacity: 0.88;
  }

  .legal-doc ul li,
  .legal-doc ol li {
    margin-bottom: 0.45rem;
  }

  .legal-doc ul li::marker {
    color: var(--accent);
  }

  .legal-doc ol li::marker {
    color: var(--accent);
    font-weight: 600;
  }

  .legal-doc strong {
    color: var(--fg);
    font-weight: 700;
  }

  .legal-divider {
    border: none;
    border-top: 1px solid var(--card-border);
    margin: 2rem 0;
    opacity: 0.4;
  }

  .legal-meta {
    font-size: 0.82rem;
    opacity: 0.55;
    margin-bottom: 2rem;
    color: var(--fg);
  }

  .section-block {
    margin-bottom: 0.5rem;
  }

  .bg-light {
    background-color: var(--card-bg) !important;
    color: var(--fg) !important;
  }

  .bg-dark {
    background-color: var(--card-bg) !important;
    color: var(--fg) !important;
  }