/* ============================================================
   legal.css — content & legal pages (About, Careers, Press,
   Terms, Privacy, Cookie Settings). Loads AFTER styles.css and
   reuses its nav, footer, buttons, .wrap, .eyebrow, variables.
   ============================================================ */

.lp-main{ padding-top:96px; }
@media (max-width:720px){ .lp-main{ padding-top:80px; } }

.lp-wrap{ max-width:780px; margin:0 auto; padding:0 24px 88px; }
@media (max-width:720px){ .lp-wrap{ padding-bottom:64px; } }

.lp-back{ display:inline-flex; align-items:center; gap:7px; font-size:14px; font-weight:650;
  color:var(--ink-3); margin-bottom:30px; transition:color .15s ease; }
.lp-back:hover{ color:var(--ink); }
.lp-back svg{ width:15px; height:15px; }

.lp-head{ border-bottom:1px solid var(--line); padding-bottom:34px; margin-bottom:40px; }
.lp-head .eyebrow{ margin-bottom:14px; }
.lp-title{ font-size:clamp(34px,5vw,56px); font-weight:800; letter-spacing:-0.04em;
  line-height:1.02; margin:0; text-wrap:balance; }
.lp-updated{ font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--ink-3);
  margin:18px 0 0; }
.lp-lede{ font-size:19px; line-height:1.58; color:var(--ink-2); margin:18px 0 0; max-width:62ch; }

/* body typography */
.lp-body{ font-size:16.5px; line-height:1.72; color:var(--ink-2); }
.lp-body > section{ margin-top:38px; }
.lp-body > section:first-child{ margin-top:0; }
.lp-body h2{ font-size:23px; font-weight:750; letter-spacing:-0.02em; color:var(--ink);
  line-height:1.2; margin:0 0 14px; }
.lp-body h2 .lp-num{ font-family:var(--mono); font-size:14px; font-weight:700; color:var(--ink-3);
  margin-right:12px; }
.lp-body h3{ font-size:17px; font-weight:700; color:var(--ink); margin:26px 0 10px; }
.lp-body p{ margin:0 0 14px; }
.lp-body p:last-child{ margin-bottom:0; }
.lp-body a{ color:var(--ink); text-decoration:underline; text-underline-offset:2px;
  text-decoration-color:var(--line-2); transition:text-decoration-color .15s ease; }
.lp-body a:hover{ text-decoration-color:var(--ink); }
.lp-body ul{ margin:0 0 14px; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:10px; }
.lp-body ul li{ position:relative; padding-left:26px; }
.lp-body ul li::before{ content:''; position:absolute; left:6px; top:11px; width:6px; height:6px;
  border-radius:50%; background:var(--ink-3); }
.lp-body strong{ color:var(--ink); font-weight:700; }

/* callout / note box */
.lp-note{ background:var(--surface); border:1px solid var(--line); border-radius:16px;
  padding:22px 24px; margin:24px 0; font-size:15.5px; line-height:1.62; color:var(--ink-2); }
.lp-note strong{ color:var(--ink); }

/* definition-style table for cookie/data lists */
.lp-table{ border:1px solid var(--line); border-radius:16px; overflow:hidden; margin:22px 0; }
.lp-row{ display:grid; grid-template-columns:200px 1fr; gap:0; border-top:1px solid var(--line); }
.lp-row:first-child{ border-top:0; }
.lp-row .lp-k{ padding:16px 20px; font-weight:700; color:var(--ink); font-size:15px;
  background:var(--surface); border-right:1px solid var(--line); }
.lp-row .lp-v{ padding:16px 20px; font-size:15px; color:var(--ink-2); }
@media (max-width:600px){ .lp-row{ grid-template-columns:1fr; } .lp-row .lp-k{ border-right:0; border-bottom:1px solid var(--line); } }

/* contact card at the bottom */
.lp-contact{ margin-top:46px; padding:30px 30px; border:1px solid var(--line); border-radius:20px;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; }
.lp-contact h4{ font-size:18px; font-weight:750; letter-spacing:-0.02em; color:var(--ink); margin:0 0 4px; }
.lp-contact p{ margin:0; font-size:15px; color:var(--ink-3); }

/* content-page feature grid (About / Careers) */
.lp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin:26px 0; }
@media (max-width:600px){ .lp-grid{ grid-template-columns:1fr; } }
.lp-card{ border:1px solid var(--line); border-radius:18px; padding:24px; background:#fff; }
.lp-card h4{ font-size:16.5px; font-weight:750; color:var(--ink); margin:0 0 8px; letter-spacing:-0.01em; }
.lp-card p{ font-size:14.5px; line-height:1.6; color:var(--ink-2); margin:0; }

/* cookie settings toggles */
.ck-group{ border:1px solid var(--line); border-radius:18px; overflow:hidden; margin:26px 0; }
.ck-item{ display:flex; align-items:flex-start; justify-content:space-between; gap:20px;
  padding:22px 24px; border-top:1px solid var(--line); }
.ck-item:first-child{ border-top:0; }
.ck-item .ck-copy h4{ font-size:16px; font-weight:700; color:var(--ink); margin:0 0 6px; }
.ck-item .ck-copy p{ font-size:14px; line-height:1.55; color:var(--ink-3); margin:0; }
.ck-tag{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-3); }
/* switch */
.ck-switch{ position:relative; flex-shrink:0; width:46px; height:27px; }
.ck-switch input{ position:absolute; opacity:0; width:100%; height:100%; margin:0; cursor:pointer; }
.ck-track{ position:absolute; inset:0; background:var(--line-2); border-radius:999px; transition:background .18s ease; }
.ck-track::after{ content:''; position:absolute; top:3px; left:3px; width:21px; height:21px;
  background:#fff; border-radius:50%; transition:transform .18s ease; box-shadow:0 1px 3px rgba(0,0,0,.25); }
.ck-switch input:checked + .ck-track{ background:var(--green,#1F8A5B); }
.ck-switch input:checked + .ck-track::after{ transform:translateX(19px); }
.ck-switch input:disabled + .ck-track{ background:var(--ink-3); opacity:.5; }
.ck-switch input:disabled{ cursor:not-allowed; }
.ck-actions{ display:flex; align-items:center; gap:16px; margin-top:8px; flex-wrap:wrap; }
.ck-saved{ font-size:14px; font-weight:650; color:var(--green,#1F8A5B); opacity:0; transition:opacity .2s ease; }
.ck-saved.show{ opacity:1; }

/* ===== contact page ===== */
.contact-methods{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin:6px 0 36px; }
@media (max-width:640px){ .contact-methods{ grid-template-columns:1fr; } }
.cm-card{ border:1px solid var(--line); border-radius:18px; padding:22px; background:#fff;
  display:flex; flex-direction:column; gap:5px; transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease; }
.cm-card:hover{ transform:translateY(-2px); box-shadow:0 16px 34px -18px rgba(0,0,0,.20); border-color:var(--line-2); }
.cm-ic{ width:44px; height:44px; border-radius:12px; background:var(--surface); display:grid; place-items:center; margin-bottom:10px; }
.cm-ic svg{ width:22px; height:22px; color:var(--ink); }
.cm-label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); }
.cm-value{ font-size:16px; font-weight:750; color:var(--ink); letter-spacing:-0.01em; word-break:break-word; }
a.cm-value{ text-decoration:none; }
a.cm-value:hover{ text-decoration:underline; text-underline-offset:2px; }
.cm-sub{ font-size:13px; color:var(--ink-3); margin-top:2px; }
.cm-copy{ margin-top:8px; align-self:flex-start; font-size:12.5px; font-weight:700; color:var(--ink-3);
  background:none; border:none; cursor:pointer; padding:0; font-family:inherit; }
.cm-copy:hover{ color:var(--ink); }
.cm-copy.copied{ color:var(--green,#1F8A5B); }
.contact-info{ display:flex; flex-wrap:wrap; gap:10px 28px; margin:0 0 30px; }
.ci-chip{ display:inline-flex; align-items:center; gap:9px; font-size:14.5px; color:var(--ink-2); }
.ci-chip svg{ width:17px; height:17px; color:var(--ink-3); flex-shrink:0; }
.ci-chip strong{ color:var(--ink); font-weight:700; }
.contact-form-h{ font-size:23px; font-weight:750; letter-spacing:-0.02em; color:var(--ink); margin:8px 0 18px; }
