.policy-layout {
  display: grid;
  gap: var(--space-8);
}

@media (min-width: 992px) {
  .policy-layout {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 3fr);
    align-items: flex-start;
  }
}

.policy-toc {
  position: sticky;
  top: 6rem;
  align-self: flex-start;
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  box-shadow: var(--shadow-subtle);
  font-size: var(--font-size-sm);
}

.policy-toc ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.policy-toc a {
  color: var(--color-text-muted);
}

.policy-toc a:hover {
  color: var(--color-primary);
}

.policy-content {
  background-color: var(--color-surface-alt);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-soft);
}

.policy-section + .policy-section {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-subtle);
}

.policy-section h2 {
  margin-bottom: var(--space-3);
}

.policy-section ul {
  margin-left: 1.25rem;
  color: var(--color-text-muted);
}

.policy-section ul li {
  margin-bottom: var(--space-2);
}

.policy-cta {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border-subtle);
}

.policy-cta h2 {
  margin-bottom: var(--space-3);
}

.policy-cta p {
  margin-bottom: var(--space-4);
}

@media (max-width: 767px) {
  .policy-toc {
    position: static;
    padding: var(--space-4);
    margin-bottom: var(--space-4);
  }

  .policy-content {
    padding: var(--space-4);
  }
}
