/* ===================================================================
   LEGAL PAGES — shared styles for Privacy Policy + Terms of Service
   =================================================================== */

/* ---- Subpage overrides (no pre-flip choreography) ------------------- */
body.subpage{overflow:auto}
body.subpage #site{opacity:1 !important;visibility:visible !important}
body.subpage #navbar .nav-logo{opacity:1;transform:translateY(0)}
body.subpage #navbar .nav-links a{opacity:1;transform:translateY(0)}
body.subpage #navbar{opacity:1;transform:translateY(0)}

/* ---- Header -------------------------------------------------------- */
#legal-header{
  padding:160px 0 72px;border-bottom:1px solid var(--border);
  position:relative;overflow:hidden;
}
#legal-header::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 85% 0%, rgba(99,102,241,.05), transparent 55%);
}
.legal-breadcrumb{
  font-family:var(--font-mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--text-dim);margin-bottom:28px;
}
.legal-breadcrumb a{color:var(--text-muted);text-decoration:none;transition:color .2s ease}
.legal-breadcrumb a:hover{color:var(--accent)}
.legal-breadcrumb .sep{margin:0 10px;color:var(--text-dim)}

.legal-kicker{
  display:inline-block;padding:6px 14px;border:1px solid rgba(99,102,241,.3);border-radius:100px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--accent);margin-bottom:28px;
}
.legal-title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(40px,5vw,64px);line-height:1.05;letter-spacing:-1.5px;
  color:var(--text-primary);margin-bottom:24px;max-width:820px;
}
.legal-meta{
  display:flex;gap:24px;align-items:center;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:var(--text-dim);
}
.legal-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--text-dim)}

/* ---- Body layout --------------------------------------------------- */
#legal-body{padding:96px 0 120px;border-bottom:1px solid var(--border)}
.legal-layout{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:80px;
  align-items:flex-start;
  max-width:1120px;
  margin:0 auto;
}

/* ---- Sticky TOC ---------------------------------------------------- */
.legal-toc{
  position:sticky;top:112px;
  display:flex;flex-direction:column;gap:2px;
  border-left:1px solid var(--border);padding-left:20px;
}
.legal-toc-title{
  font-family:var(--font-mono);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;color:var(--text-dim);margin-bottom:14px;
}
.legal-toc a{
  display:block;padding:6px 0;
  font-family:var(--font-body);font-size:13px;font-weight:400;
  color:var(--text-muted);text-decoration:none;
  transition:color .2s ease;line-height:1.4;
}
.legal-toc a:hover{color:var(--accent)}
.legal-toc a .num{
  display:inline-block;width:22px;
  color:var(--text-dim);font-family:var(--font-mono);font-size:11px;
}

/* ---- Article prose ------------------------------------------------- */
.legal-article{max-width:760px;min-width:0}
.legal-lede{
  font-family:var(--font-display);font-weight:400;
  font-size:clamp(18px,1.6vw,22px);line-height:1.55;letter-spacing:-.3px;
  color:var(--text-primary);margin-bottom:48px;padding-bottom:32px;
  border-bottom:1px solid var(--border);
}

.legal-article h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(22px,2vw,28px);line-height:1.2;letter-spacing:-.5px;
  color:var(--text-primary);margin:56px 0 18px;scroll-margin-top:96px;
}
.legal-article h2 .sec-num{
  display:inline-block;margin-right:14px;
  font-family:var(--font-mono);font-size:12px;font-weight:500;
  letter-spacing:2px;color:var(--accent);vertical-align:2px;
}
.legal-article h3{
  font-family:var(--font-display);font-weight:600;
  font-size:18px;letter-spacing:-.2px;color:var(--text-primary);
  margin:32px 0 12px;
}
.legal-article p{
  font-size:15px;line-height:1.8;color:var(--text-muted);
  font-weight:300;margin-bottom:18px;
}
.legal-article p strong{color:var(--text-primary);font-weight:500}
.legal-article p em{color:var(--text-primary);font-style:italic}
.legal-article a{
  color:var(--accent);text-decoration:none;
  border-bottom:1px solid rgba(99,102,241,.3);transition:border-color .2s ease;
}
.legal-article a:hover{border-color:var(--accent)}

.legal-article ul{list-style:none;padding:0;margin:0 0 22px}
.legal-article ul li{
  position:relative;padding:4px 0 4px 22px;
  font-size:15px;line-height:1.8;color:var(--text-muted);font-weight:300;
}
.legal-article ul li::before{
  content:"";position:absolute;left:4px;top:17px;
  width:5px;height:5px;border-radius:50%;background:var(--accent);
}
.legal-article ul li strong{color:var(--text-primary);font-weight:500}

.legal-note{
  margin:24px 0;padding:18px 22px;
  border:1px solid rgba(99,102,241,.25);border-left:2px solid var(--accent);
  border-radius:0 8px 8px 0;background:rgba(99,102,241,.04);
}
.legal-note p{font-size:14px;color:var(--text-muted);margin:0}
.legal-note strong{color:var(--accent);font-weight:500}

/* ---- Close / contact block ---------------------------------------- */
.legal-contact{
  margin-top:64px;padding:32px;border:1px solid var(--border);border-radius:16px;
  background:var(--surface);
}
.legal-contact-label{
  font-family:var(--font-mono);font-size:10px;letter-spacing:3px;
  text-transform:uppercase;color:var(--text-dim);margin-bottom:12px;
}
.legal-contact h4{
  font-family:var(--font-display);font-weight:600;font-size:20px;
  color:var(--text-primary);margin-bottom:8px;
}
.legal-contact p{font-size:14px;color:var(--text-muted);margin-bottom:8px}
.legal-contact a{color:var(--accent)}

/* ---- Responsive --------------------------------------------------- */
@media (max-width:1024px){
  .legal-layout{grid-template-columns:1fr;gap:48px}
  .legal-toc{position:static;border-left:none;border-top:1px solid var(--border);padding-left:0;padding-top:20px}
}
@media (max-width:768px){
  #legal-header{padding:120px 0 56px}
  #legal-body{padding:64px 0 80px}
  .legal-article h2{font-size:22px}
}
