/* Privacy Policy page-specific styles. Keep minimal and rely on base.css. */
.policy {
  color: var(--text-primary, #e6e6e6);
}
.policy-hero {
  padding: clamp(1.25rem, 2.5vw, 2rem) 1rem;
  margin: 0 auto;
  max-width: 72rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.policy-title {
  font-size: clamp(1.75rem, 2.4vw, 2.25rem);
  line-height: 1.2;
  margin: 0.25rem 0 0.5rem 0;
}
.policy-subtitle {
  margin: 0 0 0.5rem 0;
  opacity: 0.9;
}
.policy-updated {
  font-size: 0.95rem;
  opacity: 0.8;
}
.breadcrumbs {
  font-size: 0.95rem;
  margin-bottom: 0.5rem;
}
.breadcrumbs .crumb { color: var(--link, #a6c7ff); }
.breadcrumbs .crumb-sep { margin: 0 0.5rem; opacity: 0.6; }

.policy-intro, .policy-section, .policy-cta {
  margin: 0 auto;
  padding: clamp(1rem, 2.2vw, 1.5rem) 1rem;
  max-width: 72rem;
}
.policy-toc { 
  display: grid; 
  grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr)); 
  gap: 0.5rem 1rem; 
  list-style: none; 
  padding-left: 0; 
}
.policy-toc a {
  display: inline-block;
  padding: 0.4rem 0.25rem;
  border-radius: 0.35rem;
}
.policy-toc a:focus-visible { outline: 2px solid var(--focus, #7aa2ff); outline-offset: 2px; }

.policy-section + .policy-section { border-top: 1px dashed rgba(255,255,255,0.08); }
.policy-section h2 { margin-top: 0; font-size: clamp(1.25rem, 2.1vw, 1.6rem); }
.policy-section p, .policy-section li { line-height: 1.7; }
.policy-section ul { padding-left: 1.1rem; }

.policy-cta {
  border-top: 1px solid rgba(255,255,255,0.08);
  background: linear-gradient(0deg, rgba(255,255,255,0.03), rgba(255,255,255,0.0));
  border-radius: 0.5rem;
}

/* Utility for screen reader only text if not present in base.css */
.visually-hidden { position: absolute !important; height: 1px; width: 1px; overflow: hidden; clip: rect(1px, 1px, 1px, 1px); white-space: nowrap; }
