.legal-page { padding: 140px 0 80px; }
.legal-page .container { max-width: 720px; }
.legal-header { margin-bottom: 48px; }
.legal-header h1 {
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700; line-height: 1.2;
  letter-spacing: -0.02em; margin-bottom: 12px;
}
.legal-header .legal-updated {
  font-size: 0.875rem; color: var(--text-tertiary);
}
.legal-body h2 {
  font-size: 1.125rem; font-weight: 700;
  margin: 40px 0 12px; letter-spacing: -0.01em;
}
.legal-body p {
  font-size: 0.9375rem; color: var(--text-secondary);
  line-height: 1.75; margin-bottom: 16px;
}
.legal-body ul {
  list-style: none; padding: 0; margin-bottom: 16px;
}
.legal-body li {
  font-size: 0.9375rem; color: var(--text-secondary);
  line-height: 1.75; padding-left: 20px; position: relative;
  margin-bottom: 8px;
}
.legal-body li::before {
  content: ''; position: absolute; left: 0; top: 11px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}
.legal-body a {
  color: var(--accent); text-decoration: underline;
  text-underline-offset: 3px;
}
.legal-body a:hover { opacity: 0.75; }
.legal-back {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.875rem; font-weight: 500;
  color: var(--text-secondary); margin-top: 48px;
  transition: color 0.3s;
}
.legal-back:hover { color: var(--text); }
.legal-back svg { width: 16px; height: 16px; }
