/* ============================================================================
   OMNISOLVER MODELS · legal.css — shared styling for the six legal pages.
   Load order: tokens.css -> base.css -> legal.css.
   A readable, single-column "document" that floats as a glass card on the aurora:
   ~760px column, comfortable line-height, teal section headings, depth + air.
   ============================================================================ */

/* outer shell gives the document air + lets the aurora breathe around it */
.legal-shell {
  position: relative;
  padding: var(--s-10) var(--s-5) var(--s-11);
  display: flex;
  justify-content: center;
}

/* the document column itself — a soft glass card sitting on the aurora */
.legal {
  position: relative;
  width: 100%;
  max-width: 760px;
  margin: 0;
  padding: var(--s-9) clamp(var(--s-5), 5vw, var(--s-9)) var(--s-8);
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(var(--glass-blur));
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--glass-border);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-3), var(--sh-inset);
}
/* gradient hairline along the top edge for premium depth */
.legal::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 1px;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  background: linear-gradient(90deg, transparent, var(--glass-hi), transparent);
}

/* ---- Header ------------------------------------------------------------- */
.legal-head {
  margin-bottom: var(--s-8);
  padding-bottom: var(--s-7);
  border-bottom: 1px solid var(--line);
}
.legal-head .eyebrow { display: block; margin-bottom: var(--s-3); }
.legal-head h1 {
  margin: 0 0 var(--s-4);
  font-size: var(--fs-2xl);
  letter-spacing: var(--tracking-tight);
}

/* "Последнее обновление" pill */
.legal-updated {
  display: inline-flex;
  align-items: center;
  gap: .5em;
  padding: 5px 13px;
  border-radius: var(--r-pill);
  background: var(--glass-bg);
  border: 1px solid var(--line);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--text-2);
}
.legal-updated .icon { color: var(--teal); width: 1em; height: 1em; }

.legal-lead {
  margin: var(--s-5) 0 0;
  color: var(--text-2);
  font-size: var(--fs-md);
  line-height: var(--lh-body);
  max-width: 62ch;
}

/* ---- Sections ----------------------------------------------------------- */
.legal section { margin-bottom: var(--s-8); }
.legal section:last-of-type { margin-bottom: 0; }
.legal h2 {
  font-size: var(--fs-lg);
  margin: 0 0 var(--s-4);
  font-weight: 650;
  color: var(--teal-hi);
  letter-spacing: -0.01em;
  scroll-margin-top: calc(var(--nav-h) + var(--s-4));
}
.legal h3 {
  font-size: var(--fs-md);
  margin: var(--s-6) 0 var(--s-2);
  font-weight: 650;
  color: var(--text);
}
.legal p { color: var(--text-2); margin: 0 0 var(--s-4); line-height: var(--lh-body); }
.legal section > p:last-child { margin-bottom: 0; }
.legal ul, .legal ol { color: var(--text-2); margin: 0 0 var(--s-4); padding-left: var(--s-6); }
.legal li { margin-bottom: var(--s-2); line-height: var(--lh-body); }
.legal li::marker { color: var(--teal-lo); }
.legal strong { color: var(--text); font-weight: 650; }
.legal a { color: var(--teal); font-weight: 550; }
.legal a:hover { color: var(--teal-hi); }
.legal code, .legal .mono {
  font-family: var(--font-mono);
  font-size: .9em;
  background: var(--surface-3);
  padding: 1px 6px;
  border-radius: var(--r-xs);
  color: var(--text);
  border: 1px solid var(--line-soft);
}

/* ---- Callout: honest / important notes ---------------------------------- */
.legal-note {
  display: flex;
  gap: var(--s-4);
  padding: var(--s-5);
  margin: var(--s-5) 0;
  background: var(--surface-2);
  border: 1px solid var(--line);
  border-left: 3px solid var(--copper);
  border-radius: var(--r-md);
  box-shadow: var(--sh-1);
}
.legal-note.teal {
  border-left-color: var(--teal);
  background: rgba(34, 199, 182, .055);
}
.legal-note .icon {
  flex: none;
  width: 22px;
  height: 22px;
  color: var(--copper);
  margin-top: 1px;
}
.legal-note.teal .icon { color: var(--teal); }
.legal-note p { margin: 0; font-size: var(--fs-sm); color: var(--text-2); }
.legal-note p + p { margin-top: var(--s-2); }
.legal-note strong { color: var(--text); }

/* ---- Cross-links footer ------------------------------------------------- */
.legal-foot {
  margin-top: var(--s-9);
  padding-top: var(--s-7);
  border-top: 1px solid var(--line);
}
.legal-foot .eyebrow { margin-bottom: var(--s-4); display: block; }
.legal-foot-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2) var(--s-3);
}
.legal-foot-links a {
  font-size: var(--fs-sm);
  font-weight: 550;
  color: var(--text-2);
  padding: 7px 13px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: var(--glass-bg);
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
}
.legal-foot-links a:hover {
  color: var(--teal-hi);
  border-color: var(--line-teal);
  background: var(--glass-bg-2);
  transform: translateY(-1px);
}
.legal-foot-links a[aria-current="page"] {
  color: var(--teal-hi);
  border-color: var(--line-teal);
  background: rgba(34, 199, 182, .12);
}
.legal-foot .legal-back {
  display: inline-flex;
  align-items: center;
  gap: .4em;
  margin-top: var(--s-6);
  font-size: var(--fs-sm);
  font-weight: 550;
  color: var(--text-muted);
}
.legal-foot .legal-back:hover { color: var(--teal); }
.legal-foot .legal-back .icon { transform: rotate(90deg); width: 1em; height: 1em; }

@media (max-width: 760px) {
  .legal-shell { padding: var(--s-8) var(--s-3) var(--s-9); }
  .legal { padding: var(--s-7) var(--s-5) var(--s-6); border-radius: var(--r-lg); }
}
@media (max-width: 400px) {
  .legal { padding: var(--s-6) var(--s-4) var(--s-5); }
}
