/* ============================================================
   /privacy + /cookies — long-form policy pages
   Editorial layout: hero, sticky anchor TOC, prose column capped
   around 720px so a line of body type lands at a comfortable
   reading width. Same dark canvas, same type stack as the rest
   of the site so policy pages feel part of the same product
   rather than a templated PDF.
   ============================================================ */

/* ---------- Hero ---------- */
.legal-hero {
  padding: calc(var(--nav-h) + 40px) var(--pad-x) clamp(40px, 5vw, 64px);
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 2vw, 22px);
  border-bottom: 1px solid var(--border);
  background-color: var(--bg);
  background-image: radial-gradient(circle, rgba(255, 255, 255, .035) 1px, transparent 1px);
  background-size: 28px 28px;
}
.legal-hero__eye {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.legal-hero__eye .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--blue);
  box-shadow: 0 0 0 3px rgba(91, 90, 255, .15);
}
.legal-hero__title {
  font-family: var(--font-display);
  font-weight: var(--heading-weight);
  font-size: clamp(40px, 5.6vw, 88px);
  letter-spacing: -.035em;
  line-height: 1.05;
  max-width: 22ch;
}
.legal-hero__title em { font-style: italic; font-weight: 500; color: var(--cream); }
.legal-hero__sub {
  font-size: clamp(17px, .4vw + 1rem, 20px);
  line-height: 1.55;
  color: #cfcfcf;
  max-width: 60ch;
}
.legal-hero__updated {
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ---------- Two-column layout ---------- */
.legal-layout {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  padding: clamp(48px, 6vw, 96px) var(--pad-x) clamp(72px, 9vw, 120px);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
@media (max-width: 900px) {
  .legal-layout {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* ---------- Anchor TOC ---------- */
.legal-toc {
  position: sticky;
  top: calc(var(--nav-h) + 24px);
  align-self: start;
  border-left: 1px solid var(--border);
  padding-left: 16px;
}
.legal-toc__eye {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
}
.legal-toc ol {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-direction: column;
  gap: 9px;
  counter-reset: legaltoc;
}
.legal-toc li { counter-increment: legaltoc; }
.legal-toc a {
  display: flex;
  gap: 10px;
  font-size: 13.5px;
  color: #b8b8b8;
  line-height: 1.4;
  transition: color .2s;
}
.legal-toc a::before {
  content: counter(legaltoc, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .14em;
  color: var(--muted);
  flex: 0 0 auto;
  padding-top: 2px;
}
.legal-toc a:hover { color: #fff; }

@media (max-width: 900px) {
  .legal-toc {
    position: static;
    border-left: 0;
    padding-left: 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 22px 0;
  }
  .legal-toc ol {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px 18px;
  }
}

/* ---------- Prose ---------- */
.legal-prose {
  max-width: 720px;
  font-size: clamp(16px, .25vw + 1rem, 18px);
  line-height: 1.75;
  color: #d6d6d6;
}
.legal-prose section + section { margin-top: clamp(48px, 6vw, 72px); }
.legal-prose h2 {
  font-family: var(--font-display);
  font-weight: var(--heading-weight);
  font-size: clamp(28px, 2.4vw + .8rem, 40px);
  letter-spacing: -.025em;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 .65em;
  scroll-margin-top: calc(var(--nav-h) + 16px);
}
.legal-prose h2 em { font-style: italic; font-weight: 500; color: var(--cream); }
.legal-prose h3 {
  font-family: var(--font-ui);
  font-weight: 500;
  font-size: 17px;
  letter-spacing: .005em;
  color: #fff;
  margin: 1.6em 0 .5em;
}
.legal-prose p { margin: 0 0 1.05em; }
.legal-prose p:last-child { margin-bottom: 0; }
.legal-prose strong { color: #fff; font-weight: 500; }

.legal-prose a {
  color: var(--blue);
  border-bottom: 1px solid rgba(91, 90, 255, .35);
  transition: color .2s, border-color .2s;
}
.legal-prose a:hover { color: #fff; border-bottom-color: #fff; }

.legal-prose ul {
  list-style: none;
  padding: 0;
  margin: 0 0 1.2em;
  display: flex;
  flex-direction: column;
  gap: .55em;
}
.legal-prose ul li {
  position: relative;
  padding-left: 22px;
}
.legal-prose ul li::before {
  content: "";
  position: absolute;
  left: 4px;
  top: .68em;
  width: 6px;
  height: 6px;
  border-radius: 1px;
  background: var(--blue);
  opacity: .8;
}

/* Inline mini-eyebrow for the "Last updated" / footer-style notes */
.legal-note {
  margin-top: clamp(48px, 6vw, 72px);
  padding-top: 28px;
  border-top: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ---------- "Our details" block ---------- */
.legal-details {
  margin-top: clamp(48px, 6vw, 72px);
  padding: clamp(24px, 3vw, 36px);
  border: 1px solid var(--border);
  border-radius: 8px;
  background: linear-gradient(180deg, #141414, #111);
}
.legal-details h3 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  letter-spacing: -.02em;
  margin: 0 0 14px;
  color: #fff;
}
.legal-details dl {
  display: grid;
  grid-template-columns: 160px minmax(0, 1fr);
  gap: 8px 18px;
  margin: 0;
  font-size: 14.5px;
  line-height: 1.55;
}
.legal-details dt {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  padding-top: 2px;
}
.legal-details dd { margin: 0; color: #d6d6d6; }
.legal-details dd a {
  color: var(--blue);
  border-bottom: 1px solid rgba(91, 90, 255, .35);
}
.legal-details dd a:hover { color: #fff; border-bottom-color: #fff; }
@media (max-width: 540px) {
  .legal-details dl { grid-template-columns: 1fr; gap: 4px 0; }
  .legal-details dt { padding-top: 12px; }
  .legal-details dt:first-of-type { padding-top: 0; }
}

/* ---------- Cookie table ---------- */
.cookie-table-wrap {
  margin: 1.4em 0 1.6em;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: linear-gradient(180deg, #141414, #111);
}
.cookie-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  line-height: 1.5;
}
.cookie-table thead th {
  text-align: left;
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 14px 16px;
  background: #181818;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.cookie-table tbody td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-2);
  color: #d6d6d6;
  vertical-align: top;
}
.cookie-table tbody tr:last-child td { border-bottom: 0; }
.cookie-table .ck-name {
  font-family: var(--font-mono);
  font-size: 12.5px;
  color: #fff;
}
.cookie-table .ck-tag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: .14em;
  text-transform: uppercase;
  border: 1px solid var(--border);
  color: #cfcfcf;
  white-space: nowrap;
}
.cookie-table .ck-tag.is-essential { color: var(--cream); border-color: rgba(245, 240, 220, .35); }
.cookie-table .ck-tag.is-analytics { color: var(--blue); border-color: rgba(91, 90, 255, .4); }
.cookie-table .ck-tag.is-marketing { color: var(--red); border-color: rgba(232, 69, 60, .4); }

/* Mobile — collapse into a stack of cards. Each row becomes a labelled
   block so users on small screens get a readable table without
   sideways scroll. */
@media (max-width: 720px) {
  .cookie-table-wrap { background: transparent; border: 0; }
  .cookie-table thead { display: none; }
  .cookie-table, .cookie-table tbody, .cookie-table tr, .cookie-table td {
    display: block;
    width: 100%;
  }
  .cookie-table tbody tr {
    border: 1px solid var(--border);
    border-radius: 8px;
    margin-bottom: 12px;
    background: linear-gradient(180deg, #141414, #111);
    padding: 8px 4px;
  }
  .cookie-table tbody td {
    border-bottom: 0 !important;
    padding: 8px 16px;
    display: grid;
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 12px;
  }
  .cookie-table tbody td::before {
    content: attr(data-label);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--muted);
    padding-top: 3px;
  }
}

.cookie-future {
  margin: 1em 0;
  padding: 14px 16px;
  border: 1px dashed var(--border);
  border-radius: 8px;
  font-size: 14px;
  color: #b8b8b8;
}
