/* ============================================================
   PLAI — legal & thank-you pages
   ============================================================ */
.page-hero {
  padding-top: clamp(60px, 9vw, 110px);
  padding-bottom: clamp(30px, 4vw, 50px);
}
.page-hero .eyebrow { margin-bottom: 18px; }
.page-hero h1 { font-size: clamp(36px, 6vw, 64px); letter-spacing: -0.03em; }
.page-hero .updated { margin-top: 18px; font-family: var(--font-mono); font-size: 13px; color: var(--muted-2); letter-spacing: 0.04em; }

.legal {
  max-width: 800px;
  padding-bottom: clamp(70px, 9vw, 120px);
}
.legal .toc {
  border: 1px solid var(--line); border-radius: var(--radius);
  background: var(--panel); padding: 22px 26px; margin-bottom: 48px;
}
.legal .toc h4 { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 14px; font-weight: 400; }
.legal .toc ol { margin: 0; padding-left: 20px; color: var(--muted); display: grid; gap: 8px; font-size: 15px; }
.legal .toc a:hover { color: var(--lime); }

.legal h2 {
  font-size: clamp(22px, 2.6vw, 30px); margin-top: 48px; margin-bottom: 16px;
  scroll-margin-top: 100px;
}
.legal h2 .num { color: var(--violet-hi); font-family: var(--font-mono); font-size: 0.6em; margin-right: 12px; vertical-align: middle; }
.legal h3 { font-size: 18px; margin-top: 26px; margin-bottom: 10px; }
.legal p, .legal li { color: var(--muted); font-size: 16px; line-height: 1.75; }
.legal p { margin-bottom: 16px; }
.legal ul { margin: 0 0 18px; padding-left: 22px; display: grid; gap: 9px; }
.legal li::marker { color: var(--violet); }
.legal strong { color: var(--fg); font-weight: 600; }
.legal a { color: var(--violet-hi); text-decoration: underline; text-underline-offset: 2px; }
.legal .callout {
  border: 1px solid var(--line-2); border-left: 3px solid var(--violet);
  background: var(--panel); border-radius: 0 14px 14px 0;
  padding: 18px 22px; margin: 26px 0; color: var(--muted); font-size: 15px;
}

/* thank-you */
.thanks {
  min-height: 72vh; display: grid; place-items: center; text-align: center;
  padding-block: clamp(70px, 10vw, 130px);
}
.thanks-inner { max-width: 640px; }
.thanks .check {
  width: 88px; height: 88px; margin: 0 auto 30px; border-radius: 10px;
  display: grid; place-items: center; color: #0a0911;
  background: var(--grad-brand);
  box-shadow: 0 24px 60px -24px rgba(124,92,255,0.7);
}
html.motion .thanks .check { animation: popIn .7s var(--ease) both; }
.thanks .check svg { width: 44px; height: 44px; }
@keyframes popIn { 0%{transform:scale(0.4) rotate(-12deg); opacity:0} 60%{transform:scale(1.08)} 100%{transform:scale(1); opacity:1} }
.thanks h1 { font-size: clamp(34px, 6vw, 60px); }
.thanks p { color: var(--muted); font-size: 18px; margin-top: 20px; }
.thanks-next {
  margin-top: 40px; display: grid; gap: 14px; text-align: left;
  border: 1px solid var(--line); border-radius: var(--radius-lg); background: var(--panel);
  padding: 26px 30px;
}
.thanks-next h4 { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted-2); font-weight: 400; }
.thanks-step { display: flex; gap: 14px; align-items: flex-start; }
.thanks-step .s-n { font-family: var(--font-mono); color: var(--lime); font-size: 14px; flex: none; width: 26px; }
.thanks-step b { font-family: var(--font-display); display: block; font-size: 16px; }
.thanks-step span { color: var(--muted); font-size: 14.5px; }
.thanks .hero-cta { justify-content: center; margin-top: 38px; }
