/* Page styles for tos.html (Terms of Service). Shared tokens/reset/navbar/
   footer live in base.css; this file only holds the legal-page layout. */

main {
  max-width: 760px;
  margin: 0 auto;
  padding: 48px 24px 90px;
}

h1.legal-title {
  font-family: var(--font-display);
  font-size: clamp(32px, 5vw, 46px);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 6px;
}

.legal-updated {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
}

.legal-note {
  margin: 22px 0 6px;
  padding: 14px 16px;
  border: 1px solid var(--accent-ring);
  background: var(--accent-weak);
  border-radius: 14px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-sub);
}

.legal-note b {
  color: var(--accent-bright);
}

.legal-body {
  margin-top: 26px;
}

.legal-body h2 {
  font-family: var(--font-display);
  font-size: 19px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 30px 0 10px;
  color: var(--text);
}

.legal-body h2 .num {
  color: var(--emerald-bright);
  margin-right: 8px;
  font-family: var(--font-mono);
  font-size: 15px;
}

.legal-body p,
.legal-body li {
  color: var(--text-sub);
  font-size: 14.5px;
  line-height: 1.7;
}

.legal-body p {
  margin: 8px 0;
}

.legal-body ul {
  margin: 8px 0;
  padding-left: 20px;
}

.legal-body li {
  margin: 4px 0;
}

.legal-body strong {
  color: var(--text);
}

.legal-body a {
  color: var(--emerald-bright);
}

.legal-contact {
  margin-top: 34px;
  padding: 20px 22px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  font-size: 14px;
  color: var(--text-sub);
}

.legal-contact a {
  color: var(--emerald-bright);
  font-weight: 600;
}

@media (max-width: 580px) {
  main {
    padding: 32px 16px 64px;
  }
}
