/* =========================================================
   UP2Digital — Legal/Policy pages styling
   ========================================================= */

.legal {
  padding: 140px 0 clamp(64px, 8vw, 120px);
  background: var(--bg);
}
.legal__inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

.legal__head {
  padding: 28px 0 36px;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 40px;
}
.legal__eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--up2-yellow-deep);
  margin-bottom: 18px;
}
.legal__head h1 {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  margin-bottom: 14px;
  text-wrap: balance;
}
.legal__meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.legal__body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.75;
  color: var(--ink-2);
}
.legal__body > * + * { margin-top: 1em; }
.legal__body h2 {
  font-family: var(--font-head);
  font-weight: 800;
  font-size: clamp(22px, 2.2vw, 28px);
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin-top: 2.2em;
  margin-bottom: 0.6em;
  color: var(--ink);
  text-wrap: balance;
}
.legal__body h2::before {
  content: '↑';
  color: var(--up2-yellow-deep);
  font-family: var(--font-mono);
  font-size: 0.7em;
  font-weight: 700;
  margin-right: 10px;
  vertical-align: 0.18em;
}
.legal__body h3 {
  font-family: var(--font-head);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -0.015em;
  line-height: 1.3;
  margin-top: 1.6em;
  margin-bottom: 0.5em;
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.legal__body p { text-wrap: pretty; }
.legal__body strong { color: var(--ink); font-weight: 600; }
.legal__body em { color: var(--ink-muted); }
.legal__body a {
  color: var(--ink);
  border-bottom: 2px solid var(--up2-yellow);
  padding-bottom: 1px;
  transition: background .2s;
}
.legal__body a:hover { background: var(--up2-yellow-soft); }
.legal__body ul,
.legal__body ol {
  padding-left: 28px;
}
.legal__body ul li,
.legal__body ol li {
  margin-bottom: 0.5em;
  padding-left: 4px;
}
.legal__body ol { list-style: decimal; }
.legal__body ul { list-style: none; }
.legal__body ul li { position: relative; padding-left: 22px; }
.legal__body ul li::before {
  content: '↑';
  position: absolute;
  left: 0; top: 0.1em;
  color: var(--up2-yellow-deep);
  font-family: var(--font-mono);
  font-size: 0.85em;
  font-weight: 700;
}
.legal__body code {
  font-family: var(--font-mono);
  font-size: 0.92em;
  background: var(--bg-2);
  border: 1px solid var(--hairline);
  border-radius: 4px;
  padding: 1px 6px;
}

.legal__tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 8px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  color: var(--ink-muted);
  font-weight: 500;
  background: var(--paper);
}
.legal__tag--required {
  background: var(--up2-yellow-soft);
  color: var(--up2-yellow-deep);
  border-color: rgba(245,197,24,0.3);
}

.legal__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  margin: 1.4em 0;
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: 10px;
  overflow: hidden;
}
.legal__table th,
.legal__table td {
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--hairline);
}
.legal__table th {
  background: var(--bg-2);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-2);
  font-weight: 600;
}
.legal__table tbody tr:last-child th,
.legal__table tbody tr:last-child td { border-bottom: 0; }
.legal__table code { background: transparent; border: 0; padding: 0; }

.legal__card {
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: 12px;
  padding: 20px 24px;
  margin: 1.2em 0;
}
.legal__card p { margin: 0; }

.legal__footnote {
  margin-top: 3em;
  padding-top: 24px;
  border-top: 1px solid var(--hairline);
  font-size: 14px;
  color: var(--ink-muted);
  line-height: 1.6;
}
