body {
  background-color: var(--color-bg);
}

.hero-legal {
  background: radial-gradient(circle at top left, var(--color-primary-soft), transparent 55%),
    radial-gradient(circle at bottom right, #e0f2fe, transparent 55%);
}

.hero-legal-inner {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(0, 1.4fr);
  gap: var(--space-8);
  align-items: center;
}

.hero-legal-copy {
  max-width: 36rem;
}

.hero-legal-aside {
  padding: var(--space-5);
}

.hero-legal-aside-title {
  font-size: var(--font-size-lg);
  margin-bottom: var(--space-3);
}

.hero-legal-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.hero-legal-list .badge {
  margin-right: 0.5rem;
}

.legal-content-section {
  padding-top: var(--space-8);
  padding-bottom: var(--space-16);
}

.legal-toc {
  margin-bottom: var(--space-8);
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border-subtle);
}

.legal-toc-title {
  font-size: var(--font-size-xl);
  margin-bottom: var(--space-3);
}

.legal-toc-list {
  list-style: decimal;
  padding-left: var(--space-5);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}

.legal-toc-list li {
  margin-bottom: var(--space-2);
}

.legal-toc-list a {
  text-decoration: none;
}

.legal-toc-list a:hover {
  text-decoration: underline;
}

.legal-article {
  background-color: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-border-subtle);
  padding: var(--space-6);
}

.legal-block + .legal-block {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-subtle);
}

.legal-block-last {
  margin-bottom: 0;
}

.legal-block h2 {
  font-size: var(--font-size-2xl);
  margin-bottom: var(--space-3);
}

.legal-block p,
.legal-block ul {
  font-size: var(--font-size-sm);
}

.legal-block ul {
  margin-bottom: var(--space-4);
  padding-left: var(--space-5);
}

.legal-block ul li {
  margin-bottom: var(--space-2);
}

@media (max-width: 960px) {
  .hero-legal-inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-legal-aside {
    order: -1;
  }
}

@media (max-width: 640px) {
  .legal-article {
    padding: var(--space-5);
  }

  .legal-toc {
    padding: var(--space-4);
  }

  .hero-legal-copy .hero-title {
    font-size: var(--font-size-3xl);
  }
}
