body {
  background: #0b0b0b;
  color: #f4f1ec;
}

.legal-page {
  min-height: var(--nb-viewport-height, 100vh);
  background:
    linear-gradient(180deg, rgba(12, 12, 12, 0.98) 0%, rgba(6, 6, 6, 1) 100%);
}

.legal-main {
  width: min(calc(100% - 32px), 980px);
  margin: 0 auto;
  padding: 112px 0 96px;
}

.legal-hero {
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.legal-kicker,
.legal-updated,
.legal-section__eyebrow {
  font-family: "Futura", "Trebuchet MS", sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 241, 236, 0.58);
}

.legal-title {
  margin-top: 14px;
  max-width: 12ch;
  font-size: clamp(3.2rem, 8vw, 6.8rem);
  line-height: 0.92;
  font-weight: 500;
}

.legal-lead {
  margin-top: 24px;
  max-width: 68ch;
  color: rgba(244, 241, 236, 0.72);
  font-size: 1.04rem;
  line-height: 1.75;
}

.legal-updated {
  margin-top: 18px;
}

.legal-content {
  display: grid;
  gap: 38px;
  padding-top: 44px;
}

.legal-section {
  display: grid;
  gap: 14px;
}

.legal-section h2 {
  font-size: clamp(1.55rem, 3vw, 2.4rem);
  line-height: 1.12;
  font-weight: 500;
}

.legal-section h3 {
  margin-top: 10px;
  font-size: 1.1rem;
  line-height: 1.35;
  font-weight: 500;
}

.legal-section p,
.legal-section li {
  color: rgba(244, 241, 236, 0.72);
  font-size: 0.98rem;
  line-height: 1.72;
}

.legal-section ul {
  display: grid;
  gap: 10px;
  padding-left: 20px;
}

.legal-section a {
  color: #fff;
  text-underline-offset: 3px;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  font-size: 0.94rem;
}

.legal-table th,
.legal-table td {
  padding: 14px 12px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  text-align: left;
  vertical-align: top;
}

.legal-table th {
  font-weight: 500;
  color: #fff;
}

.legal-table td {
  color: rgba(244, 241, 236, 0.72);
}

.legal-callout {
  padding: 18px 20px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.04);
}

@media (max-width: 768px) {
  .legal-main {
    width: min(calc(100% - 24px), 980px);
    padding: 78px 0 72px;
  }

  .legal-table,
  .legal-table tbody,
  .legal-table tr,
  .legal-table th,
  .legal-table td {
    display: block;
  }

  .legal-table th {
    padding-bottom: 4px;
    border-bottom: 0;
  }

  .legal-table td {
    padding-top: 0;
  }
}
