/* ================================================================
   Greenline Trading — legal.css
   Styles the Terms of Service and Privacy Policy pages.
   Inherits tokens from styles.css.
   ================================================================ */

.legal-page {
  background: var(--cream);
  padding: clamp(var(--space-12), 6vw, var(--space-20)) 0 var(--space-24);
}

.legal-container {
  max-width: 760px;
}

/* ---------- Header ---------- */
.legal-header {
  margin-bottom: var(--space-16);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--border);
}
.legal-eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--forest-2);
  margin: 0 0 var(--space-3);
}
.legal-title {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: var(--ink);
  margin: 0 0 var(--space-4);
}
.legal-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  font-size: var(--text-xs);
  color: var(--muted);
  margin: 0;
}
.legal-meta span[aria-hidden="true"] {
  color: var(--border);
}

/* ---------- Summary callout ---------- */
.legal-summary {
  background: var(--pale-green);
  border: 1px solid rgba(31, 81, 51, 0.18);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  margin-bottom: var(--space-12);
}
.legal-summary h2 {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  margin: 0 0 var(--space-4);
  color: var(--forest);
}
.legal-summary ul {
  margin: 0 0 var(--space-4);
  padding-left: 1.25rem;
}
.legal-summary li {
  font-size: var(--text-sm);
  line-height: 1.65;
  margin-bottom: var(--space-3);
  color: var(--ink);
}
.legal-summary li:last-child {
  margin-bottom: 0;
}
.legal-summary strong {
  color: var(--forest);
  font-weight: 600;
}
.legal-summary-footnote {
  margin: 0;
  font-size: var(--text-xs);
  color: var(--muted);
  font-style: italic;
}

/* ---------- Table of contents ---------- */
.legal-toc {
  background: var(--cream-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-16);
}
.legal-toc h2 {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 var(--space-4);
}
.legal-toc ol {
  margin: 0;
  padding: 0;
  list-style: none;
  columns: 1;
  column-gap: var(--space-8);
}
@media (min-width: 640px) {
  .legal-toc ol {
    columns: 2;
  }
}
.legal-toc li {
  break-inside: avoid;
  margin-bottom: var(--space-2);
}
.legal-toc a {
  font-size: var(--text-sm);
  color: var(--ink);
  line-height: 1.5;
  border-bottom: 1px solid transparent;
  transition: color 0.15s, border-color 0.15s;
}
.legal-toc a:hover {
  color: var(--forest);
  border-bottom-color: var(--forest-2);
}

/* ---------- Sections ---------- */
.legal-section {
  margin-bottom: var(--space-12);
  scroll-margin-top: 90px;
}
.legal-section h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 var(--space-4);
  line-height: 1.2;
}
.legal-section h3 {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--forest);
  margin: var(--space-6) 0 var(--space-3);
  line-height: 1.3;
}
.legal-section p {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--ink);
  margin: 0 0 var(--space-4);
}
.legal-section p:last-child {
  margin-bottom: 0;
}
.legal-section ul,
.legal-section ol {
  margin: 0 0 var(--space-4);
  padding-left: 1.5rem;
}
.legal-section li {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--ink);
  margin-bottom: var(--space-2);
}
.legal-section li ul {
  margin-top: var(--space-2);
  padding-left: 1.25rem;
}
.legal-section a {
  color: var(--forest);
  text-decoration: underline;
  text-decoration-color: var(--forest-2);
  text-underline-offset: 2px;
}
.legal-section a:hover {
  color: var(--forest-dark);
}
.legal-section strong {
  font-weight: 600;
  color: var(--ink);
}

/* Capitalized emphasis for disclaimers / liability blocks */
.caps-emphasis {
  font-size: var(--text-sm) !important;
  line-height: 1.7 !important;
  letter-spacing: 0.01em;
  padding: var(--space-4) var(--space-5);
  background: var(--cream-2);
  border-left: 3px solid var(--forest-2);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
}

/* Risk disclosure callout */
.risk-box {
  font-size: var(--text-base) !important;
  line-height: 1.65 !important;
  padding: var(--space-6);
  background: rgba(139, 47, 47, 0.06);
  border-left: 3px solid var(--error);
  border-radius: 0 var(--radius) var(--radius) 0;
  color: var(--ink);
}

/* ---------- Footnote & back link ---------- */
.legal-footnote {
  margin: var(--space-16) 0 var(--space-8);
  padding: var(--space-5);
  font-size: var(--text-xs);
  color: var(--muted);
  line-height: 1.6;
  font-style: italic;
  background: var(--cream-2);
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
}
.legal-back {
  margin: var(--space-8) 0 0;
  font-size: var(--text-sm);
}
.legal-back a {
  color: var(--forest);
  font-weight: 500;
  border-bottom: 1px solid var(--forest-2);
  padding-bottom: 2px;
  transition: color 0.15s;
}
.legal-back a:hover {
  color: var(--forest-dark);
}
