/* Lumitec AI — legal pages stylesheet (Website T&Cs, Business T&Cs, Privacy) */

@import url("styles.css?v=21");

/* Static pages (privacy / terms / contact) use .nav.nav-scrolled but don't run
   the homepage's nav-scroll JS, so --nav-progress-fast never updates. Force it
   to 1 here so the navy text/CTA colours resolve correctly. */
.nav.nav-scrolled {
  --nav-progress: 1;
  --nav-progress-fast: 1;
}

.legal-main {
  background: #fff;
  padding: 140px 24px 96px;
  min-height: 100vh;
}
.legal-wrap {
  max-width: 760px;
  margin: 0 auto;
}
.legal-eyebrow {
  font-family: var(--body); font-size: 12px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 18px;
}
.legal-h1 {
  font-family: var(--display); font-weight: 500;
  font-size: clamp(34px, 5vw, 56px); line-height: 1.08;
  letter-spacing: -0.022em;
  color: var(--neutral-800);
  text-wrap: balance;
  margin-bottom: 14px;
}
.legal-meta {
  font-family: var(--body); font-size: 14px;
  color: var(--neutral-500);
  margin-bottom: 56px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--neutral-200);
}
.legal-meta strong { color: var(--neutral-700); font-weight: 500; }

.legal-toc {
  background: var(--neutral-50);
  border: 1px solid var(--neutral-200);
  border-radius: 14px;
  padding: 20px 24px;
  margin-bottom: 56px;
}
.legal-toc-h {
  font-family: var(--body); font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--neutral-500);
  margin-bottom: 12px;
}
.legal-toc ol {
  list-style: none; padding: 0; margin: 0;
  counter-reset: toc;
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px 24px;
}
.legal-toc li {
  counter-increment: toc;
  font-family: var(--body); font-size: 14px;
}
.legal-toc li::before {
  content: counter(toc, decimal-leading-zero) "  ";
  color: var(--neutral-400); font-variant-numeric: tabular-nums;
  margin-right: 4px;
}
.legal-toc a {
  color: var(--neutral-700);
  transition: color 200ms var(--ease-out);
}
.legal-toc a:hover { color: var(--mid); }
@media (max-width: 600px) { .legal-toc ol { grid-template-columns: 1fr; } }

.legal-content {
  font-family: var(--body); font-size: 16px; line-height: 1.7;
  color: var(--neutral-700);
}
.legal-content h2 {
  font-family: var(--display); font-weight: 500;
  font-size: 24px; line-height: 1.25;
  letter-spacing: -0.012em;
  color: var(--neutral-800);
  margin: 48px 0 16px;
  scroll-margin-top: 100px;
}
.legal-content h2:first-of-type { margin-top: 0; }
.legal-content h2 .num {
  display: inline-block;
  font-family: var(--display); font-variant-numeric: tabular-nums;
  font-size: 14px; font-weight: 500; letter-spacing: 0.06em;
  color: var(--bright);
  margin-right: 12px;
  vertical-align: 2px;
}
.legal-content p { margin-bottom: 18px; max-width: 70ch; }
.legal-content p strong, .legal-content li strong { color: var(--neutral-800); font-weight: 500; }
.legal-content ul {
  list-style: none; padding: 0; margin: 0 0 18px;
}
.legal-content ul li {
  position: relative; padding-left: 22px; margin-bottom: 10px;
}
.legal-content ul li::before {
  content: ''; position: absolute; left: 4px; top: 11px;
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--bright);
}
.legal-content a {
  color: var(--mid);
  text-decoration: underline; text-decoration-color: rgba(30,136,199,0.32);
  text-underline-offset: 3px;
  transition: color 200ms var(--ease-out), text-decoration-color 200ms var(--ease-out);
  word-break: break-word;
}
.legal-content a:hover { color: var(--bright); text-decoration-color: currentColor; }
.legal-content em { font-style: italic; color: var(--neutral-600); }

.legal-details {
  margin-top: 64px; padding: 24px 28px;
  border: 1px solid var(--neutral-200);
  border-radius: 14px;
  background: var(--neutral-50);
  font-family: var(--body); font-size: 14px;
  color: var(--neutral-700); line-height: 1.65;
}
.legal-details strong { color: var(--neutral-800); font-weight: 500; }

.legal-back {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--body); font-size: 14px; font-weight: 500;
  color: var(--mid);
  margin-bottom: 32px;
  transition: color 200ms var(--ease-out), transform 200ms var(--ease-out);
}
.legal-back:hover { color: var(--bright); transform: translateX(-2px); }

@media print {
  .nav, .footer, .legal-back, .legal-toc { display: none !important; }
  .legal-main { padding: 0; }
  .legal-content { font-size: 11pt; line-height: 1.55; color: #000; }
  .legal-content h2 { color: #000; page-break-after: avoid; }
  a { color: #000 !important; text-decoration: underline; }
}
