/* ============================================================
   Lorixen — Legal pages (Privacy, Terms)
   Minimal editorial reading layout that reuses the main
   site's palette and typography. No heavy hero, no animations.
   ============================================================ */

.legal-band {
  background:
    radial-gradient(ellipse 90% 70% at 65% 20%,
      hsla(172, 85%, 28%, 0.45) 0%, transparent 60%),
    linear-gradient(180deg, #0B3B3C 0%, #072A2B 100%);
  padding-bottom: 0;
  border-bottom: 1px solid rgba(250,250,247,0.08);
}

.legal {
  max-width: 760px;
  margin: 0 auto;
  padding: clamp(56px, 7vw, 96px) 24px clamp(80px, 8vw, 120px);
  color: #1c2624;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  line-height: 1.7;
}
.legal__head { margin-bottom: clamp(36px, 4vw, 56px); }
.legal__head .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #0F766E;
  font-weight: 600;
}
.legal__head .eyebrow::before {
  content: "";
  width: 6px;
  height: 6px;
  background: #0F766E;
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(15,118,110,0.25);
}
.legal h1 {
  font-family: "Fraunces", serif;
  font-weight: 300;
  font-size: clamp(36px, 5vw, 64px);
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin: 18px 0 14px;
  color: #0B3B3C;
}
.legal__meta {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.06em;
  color: rgba(28,38,36,0.55);
  margin: 0 0 18px;
  text-transform: uppercase;
}
.legal__lede {
  font-family: "Fraunces", serif;
  font-weight: 300;
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.5;
  color: #2c3a38;
  margin: 18px 0 0;
}
.legal section {
  margin-top: clamp(28px, 3vw, 44px);
  padding-top: clamp(20px, 2vw, 28px);
  border-top: 1px solid rgba(11,59,60,0.10);
}
.legal section:first-of-type { border-top: 0; padding-top: 0; }
.legal h2 {
  font-family: "Fraunces", serif;
  font-weight: 400;
  font-size: clamp(22px, 2.4vw, 28px);
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: #0B3B3C;
  margin: 0 0 12px;
}
.legal p {
  margin: 0 0 14px;
  color: #2c3a38;
}
.legal p:last-child { margin-bottom: 0; }
.legal ul {
  margin: 0 0 14px;
  padding: 0 0 0 20px;
  color: #2c3a38;
}
.legal ul li { margin-bottom: 8px; }
.legal ul li:last-child { margin-bottom: 0; }
.legal strong { color: #0B3B3C; font-weight: 600; }
.legal a {
  color: #0F766E;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color .15s;
}
.legal a:hover { color: #C45A3F; }

.legal__back {
  margin-top: clamp(40px, 5vw, 64px);
  padding-top: clamp(24px, 2.5vw, 32px);
  border-top: 1px solid rgba(11,59,60,0.10);
  font-family: "JetBrains Mono", monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.legal__back a {
  text-decoration: none;
  color: #0F766E;
}
.legal__back a:hover { color: #C45A3F; }

main:has(> .legal) {
  background: #FAFAF7;
}

@media (max-width: 720px) {
  .legal { font-size: 15px; }
  .legal h1 { font-size: 36px; }
  .legal h2 { font-size: 20px; }
  .legal__lede { font-size: 17px; }
}
