/* ============================================================
   Legal pages — typography & layout for long-form policy text.
   ============================================================ */

.legal{
  padding:80px 0 120px;
  background:var(--paper);
}
.legal-grid{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:64px;
  align-items:start;
}
.legal-toc{
  position:sticky; top:96px;
  border-top:1px solid var(--line);
  padding-top:24px;
}
.legal-toc .l{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--mute);
  margin-bottom:18px;
}
.legal-toc ol{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:10px;
}
.legal-toc a{
  display:flex; gap:10px; align-items:baseline;
  font-family:var(--body); font-size:13.5px;
  color:var(--ink-3);
  transition:color .2s;
}
.legal-toc a:hover{ color:var(--ink) }
.legal-toc .n{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.14em; color:var(--mute);
  flex:0 0 28px;
}

.legal-body{
  font-family:var(--body);
  font-size:15.5px;
  line-height:1.65;
  color:var(--ink-2);
  max-width:760px;
}
.legal-body h2{
  font-family:var(--sans); font-weight:500;
  font-size:26px; letter-spacing:-.015em;
  line-height:1.2;
  margin:64px 0 16px;
  padding-top:24px;
  border-top:1px solid var(--line);
  color:var(--ink);
}
.legal-body h2:first-child{ border-top:none; padding-top:0; margin-top:0 }
.legal-body h2 .n{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; color:var(--cobalt);
  display:block; margin-bottom:10px;
  text-transform:uppercase; font-weight:500;
}
.legal-body h3{
  font-family:var(--sans); font-weight:500;
  font-size:18px; letter-spacing:-.005em;
  margin:32px 0 12px;
  color:var(--ink);
}
.legal-body p{ margin:0 0 16px; text-wrap:pretty }
.legal-body ul, .legal-body ol{
  margin:0 0 16px;
  padding-left:22px;
}
.legal-body li{ margin-bottom:8px }
.legal-body a{ color:var(--cobalt); text-decoration:underline; text-decoration-thickness:1px }
.legal-body a:hover{ color:var(--cobalt-2) }
.legal-body strong{ color:var(--ink); font-weight:500 }
.legal-body code,
.legal-body kbd{
  font-family:var(--mono); font-size:.92em;
  background:var(--paper-2);
  padding:1px 6px; border:1px solid var(--line); border-radius:3px;
}

.legal-body .meta-card{
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:var(--rad);
  padding:24px 28px;
  margin:0 0 48px;
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}
.legal-body .meta-card .l{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.18em; text-transform:uppercase; color:var(--mute);
}
.legal-body .meta-card .v{
  font-family:var(--sans); font-weight:500; font-size:15px;
  margin-top:8px; color:var(--ink); letter-spacing:-.005em;
}

/* table for cookie classes */
.legal-table{
  width:100%; border-collapse:collapse;
  font-family:var(--body); font-size:14px;
  border:1px solid var(--line);
  margin:8px 0 24px;
}
.legal-table th, .legal-table td{
  padding:12px 14px;
  border-bottom:1px solid var(--line);
  border-right:1px solid var(--line);
  text-align:left;
  vertical-align:top;
  line-height:1.5;
}
.legal-table tr:last-child td{ border-bottom:none }
.legal-table th:last-child, .legal-table td:last-child{ border-right:none }
.legal-table thead th{
  background:var(--paper-2);
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.14em; text-transform:uppercase; color:var(--mute);
  font-weight:500;
}
.legal-table code{
  font-family:var(--mono); font-size:12.5px;
  color:var(--ink);
}

@media (max-width:980px){
  .legal-grid{ grid-template-columns:1fr; gap:32px }
  .legal-toc{ position:static }
  .legal-body .meta-card{ grid-template-columns:1fr 1fr; gap:18px }
}
@media (max-width:640px){
  .legal-body .meta-card{ grid-template-columns:1fr }
}
