/* Design tokens live in site.css (loaded via includes/site-head.php) */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  line-height: 1.7;
  font-size: var(--text-base);
  -webkit-font-smoothing: antialiased;
}

.legal-main a,
.verify-main a,
.exam-hero a,
.exam-content a,
.exam-sidebar a,
.portal-auth a,
.portal-auth-card a,
.portal-footer-links a,
.portal-auth-back a,
.portal-dash-card a,
.portal-exams-list-page .portal-exams-card-text a,
body > footer a {
  color: var(--accent);
}

.legal-main a:hover,
.verify-main a:hover,
.exam-hero a:hover,
.exam-content a:hover,
.exam-sidebar a:hover,
.portal-auth a:hover,
.portal-auth-card a:hover,
.portal-footer-links a:hover,
.portal-auth-back a:hover,
.portal-dash-card a:hover,
.portal-exams-list-page .portal-exams-card-text a:hover,
body > footer a:hover {
  color: var(--accent-hover);
}

.legal-main {
  max-width: var(--max);
  margin: 0 auto;
  padding: 3rem 1.5rem 4rem;
}

.legal-main h1 {
  font-family: var(--serif);
  font-size: clamp(1.75rem, 3vw, 2.25rem);
  color: var(--navy);
  font-weight: 700;
  margin-bottom: 0.5rem;
  line-height: 1.2;
}

.legal-updated {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: 2rem;
}

.legal-main h2 {
  font-family: var(--serif);
  font-size: 1.25rem;
  color: var(--navy);
  font-weight: 700;
  margin: 2rem 0 0.75rem;
}

.legal-main p,
.legal-main li {
  margin-bottom: 1rem;
  color: var(--text);
}

.legal-main ul {
  margin: 0 0 1rem 1.25rem;
}

.legal-main li { margin-bottom: 0.5rem; }

body > footer,
.site-footer {
  background: var(--navy);
  color: rgba(255, 255, 255, 0.88);
}

.footer-main {
  max-width: var(--max);
  margin: 0 auto;
  padding: 3rem 1.5rem 2rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem;
}

.footer-main h4 {
  font-family: var(--serif);
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 0.75rem;
}

.footer-main p,
.footer-main a {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.78);
  text-decoration: none;
  display: block;
  margin-bottom: 0.4rem;
}

.footer-main a:hover { color: #fff; text-decoration: underline; }

.footer-logo strong {
  font-family: var(--serif);
  font-size: 1.125rem;
  color: #fff;
}

.disclaimer {
  max-width: var(--max);
  margin: 0 auto;
  padding: 1.25rem 1.5rem 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
  font-size: var(--text-xs);
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
}
