/* Shared styles for static legal pages (served from /public) */

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

:root {
  --ink: #14122a;
  --ink-muted: #3f4258;
  --ink-faint: #5c5f70;
  --link: #2a3d6e;
  --link-hover: #14122a;
  --serif: "Newsreader", "Times New Roman", times, serif;
  --sans: "DM Sans", system-ui, sans-serif;
  --pad: clamp(1.1rem, 4vw, 2.4rem);
  --measure: 40rem;
  --wide: min(100%, 50rem);
  color-scheme: only light;
  font-family: var(--serif);
  font-size: 1.0625rem;
  line-height: 1.6;
  color: var(--ink-muted);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body {
  margin: 0;
  min-height: 100vh;
  min-height: 100dvh;
  overflow-x: clip;
  background:
    radial-gradient(120% 80% at 0% 0%, rgba(74, 122, 184, 0.06) 0%, transparent 50%),
    radial-gradient(90% 60% at 100% 10%, rgba(91, 61, 122, 0.05) 0%, transparent 45%),
    linear-gradient(168deg, #f7f4fa 0%, #fbf9fc 45%, #eef0f6 100%);
}

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

a {
  color: var(--link);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
}

a:hover {
  color: var(--link-hover);
}

.legal {
  max-width: var(--wide);
  margin: 0 auto;
  padding: clamp(1.5rem, 4vw, 2.5rem) var(--pad) clamp(2.5rem, 6vw, 4rem);
}

.legal__back {
  font-family: var(--sans);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 1.75rem;
}

.legal__back a {
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1px solid rgba(42, 61, 110, 0.35);
}

.legal__back a:hover {
  color: var(--link);
  border-bottom-color: rgba(42, 61, 110, 0.6);
}

.legal h1 {
  margin: 0 0 0.5rem;
  font-family: var(--serif);
  font-size: clamp(1.6rem, 3.2vw, 2rem);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.02em;
  line-height: 1.15;
}

.legal__updated {
  margin: 0 0 2rem;
  font-family: var(--sans);
  font-size: 0.8rem;
  color: var(--ink-faint);
}

.legal h2 {
  margin: 1.75rem 0 0.6rem;
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
}

.legal p,
.legal li {
  max-width: var(--measure);
  line-height: 1.65;
}

.legal p {
  margin: 0 0 0.9rem;
}

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

.legal li {
  margin: 0.4rem 0;
}

.legal__footer {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(20, 18, 42, 0.1);
  font-family: var(--sans);
  font-size: 0.75rem;
  color: var(--ink-faint);
}

.legal__footer a {
  color: var(--ink-muted);
  font-weight: 500;
}
