.legal-hero {
  padding: 7rem 0 4rem;
  background:
    radial-gradient(circle at var(--legal-glow-a-x, 18%) var(--legal-glow-a-y, 24%), rgba(232, 78, 27, 0.36), transparent 30%),
    radial-gradient(circle at var(--legal-glow-b-x, 78%) var(--legal-glow-b-y, 66%), rgba(29, 139, 196, 0.32), transparent 34%),
    linear-gradient(114deg, rgba(15, 30, 107, 0.96) 0%, rgba(18, 103, 174, 0.80) 50%, rgba(232, 78, 27, 0.38) 100%),
    var(--legal-hero-image),
    var(--datadoc-navy);
  background-position: center;
  background-size: cover;
  color: var(--datadoc-white);
}

.legal-hero--privacy {
  --legal-hero-image: url("../../assets/images/privacy-1.jpg");
  --legal-glow-a-x: 74%;
  --legal-glow-a-y: 22%;
  --legal-glow-b-x: 18%;
  --legal-glow-b-y: 72%;
}

.legal-hero--terms {
  --legal-hero-image: url("../../assets/images/terms-1.jpg");
  --legal-glow-a-x: 22%;
  --legal-glow-a-y: 28%;
  --legal-glow-b-x: 82%;
  --legal-glow-b-y: 68%;
}

.legal-hero--legal {
  --legal-hero-image: url("../../assets/images/legal-1.jpg");
  --legal-glow-a-x: 78%;
  --legal-glow-a-y: 70%;
  --legal-glow-b-x: 20%;
  --legal-glow-b-y: 24%;
}

.legal-hero__eyebrow {
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legal-hero h1 {
  color: var(--datadoc-white);
  font-size: clamp(2.2rem, 4vw, 4rem);
  font-weight: 800;
}

.legal-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 1.12rem;
}

.legal-page {
  background: var(--datadoc-gray-bg);
}

.legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2rem;
  padding: 4rem 0;
}

.legal-toc {
  position: sticky;
  top: calc(var(--datadoc-header-height) + 1.25rem);
  padding: 1rem;
  border: 1px solid rgba(160, 168, 184, 0.25);
  border-radius: 0.65rem;
  background: var(--datadoc-white);
}

.legal-toc h2 {
  color: var(--datadoc-navy);
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.legal-toc a {
  display: block;
  padding: 0.42rem 0;
  color: var(--datadoc-gray-dark);
  font-size: 0.92rem;
  text-decoration: none;
}

.legal-toc a:hover,
.legal-toc a:focus {
  color: var(--datadoc-blue);
}

.legal-document {
  padding: clamp(1.25rem, 4vw, 3rem);
  border: 1px solid rgba(160, 168, 184, 0.25);
  border-radius: 0.75rem;
  background: var(--datadoc-white);
  box-shadow: 0 22px 56px rgba(26, 46, 143, 0.08);
}

.legal-summary {
  display: grid;
  gap: 1rem;
  margin-bottom: 2.5rem;
}

.legal-summary__item {
  padding: 1rem;
  border-left: 4px solid var(--datadoc-blue);
  border-radius: 0.55rem;
  background: rgba(27, 139, 212, 0.08);
}

.legal-summary__item strong {
  display: block;
  margin-bottom: 0.2rem;
  color: var(--datadoc-navy);
}

.legal-section {
  padding-top: 1.25rem;
  margin-top: 1.25rem;
  border-top: 1px solid rgba(160, 168, 184, 0.25);
}

.legal-section:first-child {
  padding-top: 0;
  margin-top: 0;
  border-top: 0;
}

.legal-section h2 {
  color: var(--datadoc-navy);
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  font-weight: 800;
}

.legal-section p,
.legal-section li {
  color: var(--datadoc-gray-dark);
  line-height: 1.75;
}

.legal-contact-card {
  display: grid;
  gap: 0.75rem;
  padding: 1.25rem;
  border-radius: 0.65rem;
  background: var(--datadoc-gray-bg);
}

.legal-data-table {
  overflow-x: auto;
  margin-top: 1rem;
  border: 1px solid rgba(160, 168, 184, 0.28);
  border-radius: 0.65rem;
}

.legal-data-table table {
  min-width: 760px;
  margin: 0;
}

.legal-data-table th {
  color: var(--datadoc-navy);
  background: rgba(27, 139, 212, 0.08);
}

@media (min-width: 992px) {
  .legal-layout {
    grid-template-columns: 280px minmax(0, 1fr);
    align-items: start;
  }
}
