/* Legal pages — Crossing Cloud */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;1,400&display=swap");

:root {
  --cc-blue: #2D6CB0;
  --cc-blue-deep: #1F4E83;
  --cc-blue-night: #0E2540;
  --cc-cream: #F7F2EC;
  --cc-paper: #FBFAF7;
  --cc-ink: #0B1220;
  --cc-ink-2: #1A2434;
  --cc-mute: #5A6679;
  --cc-rule: #DCD4C8;
  --cc-sans: "Geist", "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;
  --cc-mono: "Geist Mono", "JetBrains Mono", ui-monospace, "SF Mono", monospace;
  --cc-serif: "Cormorant Garamond", Georgia, serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--cc-paper);
  color: var(--cc-ink);
  font-family: var(--cc-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.005em;
}

a { color: var(--cc-blue); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

.legal-nav {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(251, 250, 247, 0.85);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--cc-rule);
}
.legal-nav-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 18px clamp(20px, 4vw, 48px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.legal-brand {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--cc-ink); font-weight: 600; letter-spacing: -0.01em; font-size: 15px;
}
.legal-brand img { width: 26px; height: 26px; border-radius: 5px; }
.legal-back {
  font-family: var(--cc-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--cc-mute);
}
.legal-back:hover { color: var(--cc-blue); text-decoration: none; }

.legal-hero {
  max-width: 980px;
  margin: 0 auto;
  padding: clamp(56px, 8vw, 96px) clamp(20px, 4vw, 48px) 32px;
}
.legal-eyebrow {
  font-family: var(--cc-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cc-blue);
  margin: 0 0 18px;
}
.legal-hero h1 {
  font-family: var(--cc-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 18px;
  color: var(--cc-ink);
  text-wrap: balance;
}
.legal-meta {
  font-family: var(--cc-mono);
  font-size: 12px;
  color: var(--cc-mute);
  letter-spacing: 0.04em;
}

.legal-body {
  max-width: 720px;
  margin: 0 auto;
  padding: 24px clamp(20px, 4vw, 48px) clamp(80px, 10vw, 140px);
  font-size: 16px;
  line-height: 1.72;
  color: var(--cc-ink-2);
}

.legal-body h1 {
  font-family: var(--cc-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(28px, 3.6vw, 40px);
  letter-spacing: -0.015em;
  margin: 56px 0 18px;
  color: var(--cc-ink);
  line-height: 1.15;
}
.legal-body h2 {
  font-size: clamp(20px, 2.4vw, 26px);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin: 48px 0 14px;
  color: var(--cc-ink);
  padding-top: 28px;
  border-top: 1px solid var(--cc-rule);
}
.legal-body h2:first-child { padding-top: 0; border-top: 0; margin-top: 0; }
.legal-body h3 {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.005em;
  margin: 32px 0 10px;
  color: var(--cc-ink);
}
.legal-body h4 {
  font-size: 15px; font-weight: 600; margin: 24px 0 8px; color: var(--cc-ink);
}

.legal-body p { margin: 0 0 16px; }
.legal-body strong { color: var(--cc-ink); font-weight: 600; }
.legal-body em { font-style: italic; }

.legal-body ul, .legal-body ol { padding-left: 22px; margin: 0 0 18px; }
.legal-body li { margin: 0 0 8px; }
.legal-body li::marker { color: var(--cc-mute); }

.legal-body hr {
  border: none;
  border-top: 1px solid var(--cc-rule);
  margin: 40px 0;
}

.legal-body table {
  width: 100%;
  border-collapse: collapse;
  margin: 16px 0 24px;
  font-size: 14px;
}
.legal-body th, .legal-body td {
  text-align: left;
  padding: 10px 12px;
  border: 1px solid var(--cc-rule);
  vertical-align: top;
}
.legal-body th { background: var(--cc-cream); font-weight: 600; color: var(--cc-ink); }

.legal-body code {
  font-family: var(--cc-mono); font-size: 0.9em;
  background: var(--cc-cream); padding: 1px 6px; border-radius: 4px;
}

.legal-body blockquote {
  margin: 18px 0;
  padding: 4px 0 4px 18px;
  border-left: 2px solid var(--cc-blue);
  color: var(--cc-ink-2);
}

.legal-footer {
  border-top: 1px solid var(--cc-rule);
  background: var(--cc-cream);
}
.legal-footer-inner {
  max-width: 1180px;
  margin: 0 auto;
  padding: 36px clamp(20px, 4vw, 48px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  font-family: var(--cc-mono);
  font-size: 12px;
  color: var(--cc-mute);
  letter-spacing: 0.04em;
}
.legal-footer a { color: var(--cc-mute); }
.legal-footer-links { display: flex; gap: 22px; flex-wrap: wrap; }

@media print {
  .legal-nav, .legal-footer { display: none; }
  .legal-hero, .legal-body { max-width: none; padding: 24px 32px; }
  body { background: white; }
}

/* Mobile: keep wide tables (e.g. the CCPA categories table) from blowing out
   the viewport — let them scroll horizontally instead. */
@media (max-width: 720px) {
  .legal-body table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .legal-body th,
  .legal-body td {
    min-width: 110px;
    font-size: 13px;
  }
}
