/* AstroTown · Legal Pages (Terms / Privacy / Cookies) */
@import url('../tokens.css');

.legal-content {
  max-width: 760px;
  margin: 0 auto;
  padding: var(--s8) var(--s6) var(--s16);
}

/* Header */
.legal-header {
  margin-bottom: var(--s8);
  border-bottom: 1px solid var(--border-subtle);
  padding-bottom: var(--s6);
}

.legal-eyebrow {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-glow);
  margin-bottom: var(--s3);
}

.legal-title {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--weight-black);
  color: var(--text-primary);
  letter-spacing: -0.02em;
  margin-bottom: var(--s2);
}

.legal-meta {
  font-size: var(--text-sm);
  color: var(--text-muted);
  font-family: var(--font-mono);
}

/* Table of contents */
.legal-toc {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s8);
}

.legal-toc-title {
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--s3);
}

.legal-toc-list {
  margin: 0;
  padding-left: var(--s5);
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}

.legal-toc-list a {
  font-size: var(--text-sm);
  color: var(--accent-glow);
  text-decoration: none;
  transition: color var(--t-fast) ease;
}
.legal-toc-list a:hover { color: var(--accent-pulse); }

/* Body */
.legal-body {
  display: flex;
  flex-direction: column;
  gap: var(--s8);
}

.legal-body section {
  display: flex;
  flex-direction: column;
  gap: var(--s4);
}

.legal-body h2 {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  color: var(--text-primary);
  padding-top: var(--s2);
  border-top: 1px solid var(--border-subtle);
}

.legal-body h3 {
  font-size: var(--text-md);
  font-weight: var(--weight-semibold);
  color: var(--text-secondary);
  margin-top: var(--s2);
}

.legal-body p {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.legal-body ul, .legal-body ol {
  padding-left: var(--s5);
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}

.legal-body li {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--text-secondary);
}

.legal-body strong { color: var(--text-primary); font-weight: var(--weight-semibold); }

.legal-body a {
  color: var(--accent-glow);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--t-fast) ease;
}
.legal-body a:hover { color: var(--accent-pulse); }

.legal-body code {
  font-family: var(--font-mono);
  font-size: 0.88em;
  background: var(--bg-raised);
  padding: 2px 6px;
  border-radius: var(--r-sm);
  color: var(--nebula-cyan);
}

/* Contact block */
.legal-contact {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}

.legal-contact p {
  margin: 0;
}

/* Table */
.legal-table-wrap {
  overflow-x: auto;
  border-radius: var(--r-lg);
  border: 1px solid var(--border-subtle);
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-xs);
}

.legal-table th {
  background: var(--bg-surface);
  color: var(--text-muted);
  font-weight: var(--weight-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: var(--s3) var(--s4);
  text-align: left;
  border-bottom: 1px solid var(--border-subtle);
}

.legal-table td {
  padding: var(--s3) var(--s4);
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: top;
}

.legal-table tr:last-child td { border-bottom: none; }
.legal-table tr:hover td { background: var(--bg-surface); }

/* XSL levels */
.xsl-levels {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}

.xsl-level {
  display: flex;
  align-items: flex-start;
  gap: var(--s4);
  padding: var(--s3) var(--s4);
  border-radius: var(--r-sm);
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
}

.xsl-badge {
  font-size: var(--text-xs);
  font-weight: var(--weight-black);
  letter-spacing: 0.06em;
  padding: 2px 8px;
  border-radius: var(--r-full);
  flex-shrink: 0;
  font-family: var(--font-mono);
  min-width: 36px;
  text-align: center;
}

.xsl-l0 { background: rgba(156,163,175,0.2); color: #9ca3af; }
.xsl-l1 { background: rgba(59,130,246,0.2);  color: #60a5fa; }
.xsl-l2 { background: rgba(16,185,129,0.2);  color: #34d399; }
.xsl-l3 { background: rgba(245,158,11,0.2);  color: #fbbf24; }
.xsl-l4 { background: rgba(249,115,22,0.2);  color: #fb923c; }
.xsl-l5 { background: rgba(239,68,68,0.2);   color: #f87171; }
.xsl-l6 { background: rgba(167,139,250,0.3); color: #a78bfa; }

.xsl-level div {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  padding-top: 1px;
}

/* Footer links */
.legal-footer-links {
  margin-top: var(--s10);
  padding-top: var(--s5);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  gap: var(--s4);
  align-items: center;
  flex-wrap: wrap;
}

.legal-footer-links a {
  font-size: var(--text-sm);
  color: var(--text-muted);
  text-decoration: none;
  transition: color var(--t-fast) ease;
}
.legal-footer-links a:hover { color: var(--accent-glow); }
.legal-footer-links span { color: var(--border-normal); }

@media (max-width: 600px) {
  .legal-content { padding: var(--s6) var(--s4) var(--s12); }
  .legal-title { font-size: var(--text-2xl); }
}
