:root {
  --legal-background: #f5f7fb;
  --legal-card-background: #ffffff;
  --legal-text: #1f2433;
  --legal-muted: #5e647c;
  --legal-border: rgba(15, 23, 42, 0.08);
  --legal-shadow: 0 24px 48px rgba(15, 23, 42, 0.08);
}

body.legal-page {
  margin: 0;
  min-height: 100vh;
  background: var(--legal-background);
  color: var(--legal-text);
  font-family: var(--font-body, 'Roboto', 'PingFang SC', 'Microsoft YaHei', sans-serif);
}

body.legal-page section {
  padding: 6px 0 !important;
}

.legal-shell {
  max-width: 960px;
  margin: 0 auto;
  padding: 20px 18px 40px;
}

.legal-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 18px 0 8px;
}

.legal-header h1 {
  margin: 0;
  font-family: var(--font-heading, 'Playfair Display', serif);
  font-size: clamp(2rem, 2.6vw, 2.8rem);
  color: var(--legal-text);
}

.legal-meta {
  color: var(--legal-muted);
  font-size: 0.95rem;
}

.legal-card {
  background: var(--legal-card-background);
  border-radius: 24px;
  box-shadow: var(--legal-shadow);
  border: 1px solid var(--legal-border);
  padding: clamp(24px, 4vw, 46px);
  line-height: 1.48;
  color: #000;
}

.legal-card h2 {
  margin-top: 10px;
  margin-bottom: 6px;
  font-size: clamp(1.4rem, 2.6vw, 1.85rem);
  color: var(--legal-text);
}

.legal-card h3 {
  margin-top: 8px;
  margin-bottom: 4px;
  font-size: clamp(1.1rem, 2vw, 1.25rem);
  color: var(--legal-text);
}

.legal-card section:first-of-type h2 {
  margin-top: 6px;
}

.legal-card section {
  margin: 0;
  padding: 0;
}

.legal-card section + section {
  margin-top: 14px;
}

.legal-card p {
  color: var(--legal-text);
  margin: 0 0 8px;
}

.legal-card ul {
  margin: 0 0 14px 1.1rem;
  padding: 0;
  color: var(--legal-text);
}

.legal-card ul li {
  margin-bottom: 6px;
}

.legal-card table {
  width: 100%;
  margin: 10px 0 18px;
  border-collapse: collapse;
  color: var(--legal-text);
}

.legal-card th,
.legal-card td {
  border: 1px solid var(--legal-border);
  padding: 8px 12px;
  text-align: left;
  vertical-align: top;
}

.legal-card a {
  color: var(--color-primary, #ff6f8d);
  word-break: break-word;
}

@media (max-width: 640px) {
  .legal-shell {
    padding: 20px 16px 44px;
  }

  .legal-card {
    padding: 18px;
    border-radius: 18px;
  }

  .legal-header h1 {
    font-size: clamp(1.8rem, 7vw, 2.4rem);
  }
}
