/* Terms & Conditions Page Styles - scoped and minimal to complement base.css */
.legal-hero {
  background: radial-gradient(1200px 500px at 20% 0%, rgba(138, 43, 226, 0.25), transparent),
              linear-gradient(135deg, #0b1020 0%, #151b2f 60%, #1a1030 100%);
  color: #ffffff;
  padding: 3rem 1rem;
}
.legal-hero__inner {
  max-width: 1100px;
  margin: 0 auto;
}
.legal-hero h1 {
  margin: 0 0 0.5rem 0;
  font-weight: 700;
}
.legal-hero .lead {
  max-width: 60ch;
  margin: 0.5rem 0 0;
  opacity: 0.9;
}
.legal-hero .meta {
  margin-top: 0.75rem;
  font-size: 0.95rem;
  opacity: 0.8;
}

.legal-page {
  --content-max: 1100px;
}
.legal-section, .toc, .cta-block {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 1.5rem 1rem;
}
.legal-section h2 {
  margin-bottom: 0.5rem;
}
.legal-section ul {
  padding-left: 1.25rem;
}

.toc ul {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem 1rem;
  list-style: none;
  padding-left: 0;
}
.toc a {
  text-decoration: none;
  color: #2fd3ff;
}
.toc a:hover, .toc a:focus {
  text-decoration: underline;
}

.cta-block__inner {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

/* Buttons leverage base styles; ensure contrast for outline */
.btn.btn-outline {
  border: 1px solid rgba(255,255,255,0.35);
  color: inherit;
  background: transparent;
}

/* Responsive */
@media (min-width: 720px) {
  .legal-hero { padding: 4rem 1.5rem; }
  .toc ul { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (min-width: 1024px) {
  .toc ul { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* Accessibility utilities if not provided by base.css */
.visually-hidden {
  position: absolute !important;
  height: 1px; width: 1px;
  overflow: hidden; clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap; border: 0; padding: 0; margin: -1px;
}
