
.policy-page {
  max-width: 1200px;
  margin: 0 auto;
}


.policy-intro {
  max-width: 980px;
  margin: 0 auto 2rem;
  opacity: 0.9;
  text-align: left;
}


.policy-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 2rem;
  align-items: start;
}


.policy-toc {
  position: sticky;
  top: 80px; 
  align-self: start;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 10px;
  padding: 1rem 1rem 1.2rem;
}
.policy-toc strong {
  font-size: 0.95rem;
  display: block;
  margin-bottom: .4rem;
}
.policy-toc ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
.policy-toc li {
  margin: .35rem 0;
}
.policy-toc a {
  font-size: .95rem;
  text-decoration: none;
  color: #fff;
  opacity: .85;
  word-wrap: anywhere;
}
.policy-toc a:hover {
  text-decoration: underline;
  opacity: 1;
}


.policy-content {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 1.5rem;
  text-align: left;
}
.policy-content h2 {
  font-size: 1.25rem;
  margin: 1.25rem 0 .5rem;
}
.policy-content p {
  margin: .5rem 0 1rem;
  opacity: .95;
}
.policy-list {
  margin: .25rem 0 1rem 1.25rem;
  padding: 0;
}
.policy-list li {
  margin: .25rem 0;
}


@media (max-width: 960px) {
  .policy-layout {
    grid-template-columns: 1fr;
  }
  .policy-toc {
    position: static;
  }
}


section {
  scroll-margin-top: 100px; 
}
