.legal-main {
  background: var(--paper);
  color: var(--ink);
}

.legal-hero {
  padding: 8rem 0 3rem;
  background: var(--forest);
  color: #fff;
}

.legal-hero .section-inner {
  max-width: 900px;
}

.legal-hero h1 {
  max-width: 900px;
  font-size: clamp(2.35rem, 5vw, 4.35rem);
  overflow-wrap: normal;
  hyphens: auto;
}

.legal-hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 1.08rem;
}

.legal-content {
  padding: clamp(3rem, 7vw, 5.5rem) 0;
}

.legal-layout {
  display: grid;
  grid-template-columns: minmax(0, 14rem) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}

.legal-toc {
  position: sticky;
  top: 6.5rem;
  display: grid;
  gap: 0.4rem;
}

.legal-toc a {
  padding: 0.45rem 0;
  color: var(--muted-ink);
  font-weight: 750;
  text-decoration: none;
}

.legal-toc a:hover,
.legal-toc a:focus-visible {
  color: var(--orange-dark);
}

.legal-card {
  display: grid;
  gap: 2rem;
  padding: clamp(1.25rem, 4vw, 2.25rem);
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--surface);
  box-shadow: 0 1px 0 rgba(16, 49, 47, 0.04);
}

.legal-section {
  scroll-margin-top: 7rem;
}

.legal-section + .legal-section {
  border-top: 1px solid var(--line);
  padding-top: 2rem;
}

.legal-section h2 {
  font-size: clamp(1.55rem, 3vw, 2.2rem);
}

.legal-section h3 {
  margin-top: 1.4rem;
}

.legal-section p,
.legal-section li,
.legal-address {
  color: var(--muted-ink);
}

.legal-address {
  margin: 1rem 0;
  font-style: normal;
}

.legal-list {
  margin: 1rem 0 0;
  padding-left: 1.2rem;
}

.legal-note {
  padding: 1rem;
  border-left: 4px solid var(--orange);
  background: #fff7ef;
  color: var(--ink);
}

.legal-meta {
  margin-top: 2rem;
  color: var(--muted-ink);
  font-size: 0.95rem;
}

@media (max-width: 820px) {
  .legal-layout {
    grid-template-columns: 1fr;
  }

  .legal-toc {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.2rem 1rem;
  }
}

@media (max-width: 560px) {
  .legal-hero {
    padding-top: 6.25rem;
  }

  .legal-hero h1 {
    font-size: 2rem;
    line-height: 1.1;
  }

  .legal-toc {
    grid-template-columns: 1fr;
  }
}
