/* Standalone legal pages */

*, *::before, *::after { box-sizing: border-box; }

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
  background: hsl(240, 2%, 12%);
  color: hsl(0, 0%, 84%);
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  line-height: 1.65;
}

.legal-page {
  width: 100%;
  max-width: 860px;
  min-height: 100vh;
  margin: 0 auto;
  padding: 24px 16px 56px;
}

.legal-topbar {
  margin-bottom: 28px;
}

.legal-topbar a {
  color: hsl(45, 100%, 72%);
  text-decoration: none;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.legal-topbar a:hover { text-decoration: underline; }

.legal-brand {
  background: linear-gradient(145deg, hsl(240, 2%, 16%), hsl(240, 2%, 13%));
  border: 1px solid hsl(0, 0%, 22%);
  border-radius: 16px;
  padding: 24px;
  margin-bottom: 28px;
}

.legal-brand h1 {
  color: #fafafa;
  font-size: clamp(1.4rem, 5vw, 1.85rem);
  font-weight: 600;
  margin: 0 0 6px;
  line-height: 1.25;
}

.legal-brand .legal-subtitle {
  color: hsl(45, 100%, 72%);
  font-size: 14px;
  font-weight: 500;
  margin: 0 0 14px;
}

.legal-brand .legal-meta {
  color: hsl(0, 0%, 70%);
  font-size: 13px;
  margin: 0;
}

.legal-contact-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  background: hsl(240, 2%, 14%);
  border: 1px solid hsl(0, 0%, 22%);
  border-radius: 12px;
  padding: 18px;
  margin-bottom: 28px;
}

.legal-contact-card div {
  font-size: 14px;
  line-height: 1.5;
}

.legal-contact-card strong {
  display: block;
  color: hsl(0, 0%, 70%);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.legal-contact-card a {
  color: hsl(45, 100%, 72%);
  text-decoration: none;
  word-break: break-word;
}

.legal-contact-card a:hover { text-decoration: underline; }

.legal-pseb-badge {
  background: linear-gradient(145deg, hsl(45, 40%, 18%), hsl(240, 2%, 14%));
  border: 1px solid hsl(45, 100%, 72%);
  border-radius: 12px;
  padding: 20px 22px;
  margin-bottom: 28px;
}

.legal-pseb-badge .legal-pseb-title {
  color: hsl(45, 100%, 72%);
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 10px;
}

.legal-pseb-badge p {
  color: hsl(0, 0%, 84%);
  font-size: 14px;
  line-height: 1.65;
  margin: 0 0 8px;
}

.legal-pseb-badge p:last-child {
  margin-bottom: 0;
}

.legal-pseb-badge strong {
  color: #fafafa;
}

.legal-toc {
  background: hsl(240, 2%, 14%);
  border: 1px solid hsl(0, 0%, 22%);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 28px;
}

.legal-toc h2 {
  color: #fafafa;
  font-size: 15px;
  font-weight: 600;
  margin: 0 0 12px;
}

.legal-toc ol {
  margin: 0;
  padding-left: 1.25rem;
}

.legal-toc li {
  margin-bottom: 6px;
}

.legal-toc a {
  color: hsl(0, 0%, 84%);
  font-size: 14px;
  text-decoration: none;
}

.legal-toc a:hover { color: hsl(45, 100%, 72%); }

.legal-content {
  overflow-wrap: break-word;
}

.legal-content h2 {
  color: #fafafa;
  font-size: clamp(16px, 4vw, 18px);
  font-weight: 600;
  margin: 32px 0 12px;
  padding-top: 8px;
  line-height: 1.35;
}

.legal-content h2:first-child { margin-top: 0; }

.legal-content p {
  margin: 0 0 14px;
  font-size: clamp(14px, 3.5vw, 15px);
}

.legal-content ul, .legal-content ol {
  margin: 0 0 16px;
  padding-left: 1.35rem;
}

.legal-content li {
  margin-bottom: 8px;
  font-size: clamp(14px, 3.5vw, 15px);
}

.legal-content a {
  color: hsl(45, 100%, 72%);
  word-break: break-word;
}

.legal-content code {
  background: hsl(240, 2%, 16%);
  color: hsl(45, 100%, 72%);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 0.9em;
}

.legal-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0;
  font-size: 14px;
}

.legal-content th,
.legal-content td {
  border: 1px solid hsl(0, 0%, 22%);
  padding: 10px 12px;
  text-align: left;
}

.legal-content th {
  background: hsl(240, 2%, 16%);
  color: #fafafa;
  font-weight: 600;
}

.legal-footer {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid hsl(0, 0%, 22%);
}

.legal-footer p {
  color: hsl(0, 0%, 70%);
  font-size: 13px;
  margin: 0 0 16px;
}

.legal-nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.legal-nav a {
  display: block;
  color: hsl(0, 0%, 84%);
  font-size: 14px;
  text-decoration: none;
  padding: 10px 14px;
  border-radius: 8px;
  background: hsl(240, 2%, 14%);
  border: 1px solid hsl(0, 0%, 22%);
}

.legal-nav a:hover,
.legal-nav a.active {
  color: hsl(45, 100%, 72%);
  border-color: hsl(45, 100%, 72%);
}

@media (min-width: 520px) {
  .legal-page { padding: 32px 24px 64px; }
  .legal-contact-card { grid-template-columns: 1fr 1fr; }
  .legal-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (min-width: 768px) {
  .legal-page { padding: 48px 32px 72px; }
  .legal-contact-card { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 992px) {
  .legal-page { padding: 56px 40px 80px; }
  .legal-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
  }
  .legal-nav a {
    display: inline-block;
    padding: 6px 0;
    background: none;
    border: none;
    border-radius: 0;
  }
  .legal-nav a.active { border-bottom: 1px solid hsl(45, 100%, 72%); }
}
