/* =========================================================
   SALA — Legal / policy pages (Privacy, Terms) + Security trust
   Shares tokens from styles.css
   ========================================================= */

/* ---------- Hero ---------- */
.legal-hero{ padding:72px 0 40px; border-bottom:1px solid var(--line);
  background:radial-gradient(820px 380px at 16% -20%, var(--blue-tint) 0%, rgba(233,240,255,0) 60%); }
.legal-hero .eyebrow{ margin-bottom:18px; }
.legal-hero h1{ font-size:clamp(34px,4vw,52px); letter-spacing:-0.03em; max-width:18ch; }
.legal-meta{ display:flex; flex-wrap:wrap; gap:10px 26px; align-items:center; margin-top:24px; }
.legal-meta .lm{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--muted);
  display:inline-flex; align-items:center; gap:8px; }
.legal-meta .lm b{ color:var(--ink-2); font-weight:600; }
.legal-intro{ margin-top:22px; max-width:62ch; font-size:18px; color:var(--ink-2); line-height:1.6; }

/* ---------- Layout: sticky TOC + prose ---------- */
.legal-layout{ display:grid; grid-template-columns:248px 1fr; gap:64px;
  max-width:var(--maxw); margin:0 auto; padding:64px var(--gutter) 110px; align-items:start; }

.legal-toc{ position:sticky; top:96px; }
.legal-toc .toc-label{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--muted-2); margin:0 0 14px; }
.legal-toc ol{ list-style:none; margin:0; padding:0; counter-reset:toc; display:flex; flex-direction:column; gap:2px; }
.legal-toc li{ counter-increment:toc; }
.legal-toc a{ display:flex; gap:11px; padding:7px 12px; border-radius:9px; font-size:14px; line-height:1.35;
  color:var(--muted); border-left:2px solid transparent; transition:background .15s, color .15s; }
.legal-toc a::before{ content:counter(toc,decimal-leading-zero); font-family:var(--mono); font-size:11px;
  color:var(--muted-2); padding-top:2px; flex:none; }
.legal-toc a:hover{ background:var(--bg-soft); color:var(--ink); }
.legal-toc a.active{ color:var(--blue); background:var(--blue-tint); }
.legal-toc a.active::before{ color:var(--blue); }

/* ---------- Prose ---------- */
.legal-body{ max-width:72ch; }
.legal-body section{ scroll-margin-top:92px; padding-bottom:40px; }
.legal-body section + section{ border-top:1px solid var(--line-2); padding-top:40px; }
.legal-body h2{ font-size:24px; letter-spacing:-0.02em; display:flex; align-items:baseline; gap:14px; }
.legal-body h2 .sn{ font-family:var(--mono); font-size:14px; font-weight:500; color:var(--blue);
  letter-spacing:0; flex:none; }
.legal-body h3{ font-size:17px; font-weight:600; margin:26px 0 0; letter-spacing:-0.01em; }
.legal-body p{ color:var(--ink-2); font-size:16px; line-height:1.65; margin:14px 0 0; }
.legal-body ul{ margin:14px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:10px; }
.legal-body ul li{ position:relative; padding-left:24px; color:var(--ink-2); font-size:16px; line-height:1.6; }
.legal-body ul li::before{ content:""; position:absolute; left:4px; top:10px; width:6px; height:6px;
  border-radius:50%; background:var(--blue); }
.legal-body ul li b{ color:var(--ink); font-weight:600; }
.legal-body a.inline{ color:var(--blue); font-weight:500; border-bottom:1px solid var(--blue-tint-2); }
.legal-body a.inline:hover{ border-color:var(--blue); }
.legal-body strong{ color:var(--ink); font-weight:600; }

/* callout */
.callout{ margin:22px 0 0; background:var(--bg-soft); border:1px solid var(--line);
  border-radius:14px; padding:20px 22px; }
.callout .ck{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--blue); margin:0 0 8px; }
.callout p{ margin:0; font-size:15px; }

/* definition rows */
.deflist{ margin:16px 0 0; display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line-2); }
.deflist .row{ display:grid; grid-template-columns:200px 1fr; gap:20px; padding:14px 0;
  border-bottom:1px solid var(--line-2); }
.deflist .row dt{ font-weight:600; color:var(--ink); font-size:15px; }
.deflist .row dd{ margin:0; color:var(--muted); font-size:15px; line-height:1.55; }

/* contact card at end */
.legal-contact{ margin-top:40px; background:var(--navy); color:#fff; border-radius:var(--radius-lg);
  padding:34px 36px; display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap; }
.legal-contact h4{ font-size:21px; color:#fff; letter-spacing:-0.02em; }
.legal-contact p{ color:#aebbd9; margin:8px 0 0; font-size:15px; max-width:42ch; line-height:1.55; }

@media (max-width:860px){
  .legal-layout{ grid-template-columns:1fr; gap:0; padding-top:40px; }
  .legal-toc{ position:static; margin-bottom:36px; padding-bottom:28px; border-bottom:1px solid var(--line); }
  .legal-toc ol{ display:grid; grid-template-columns:1fr 1fr; gap:2px 18px; }
  .deflist .row{ grid-template-columns:1fr; gap:4px; }
}

/* =========================================================
   SECURITY — trust page
   ========================================================= */
.sec-hero{ padding:84px 0 64px; position:relative; overflow:hidden;
  background:radial-gradient(900px 460px at 80% -20%, var(--blue-tint) 0%, rgba(233,240,255,0) 62%); }
.sec-hero .wrap{ position:relative; z-index:2; }
.sec-hero h1{ font-size:clamp(38px,5vw,68px); letter-spacing:-0.035em; max-width:15ch; margin-top:20px; }
.sec-hero .lead{ margin-top:22px; max-width:56ch; }
.sec-hero-octo{ position:absolute; right:-60px; top:-40px; width:360px; opacity:.06; pointer-events:none; }

/* trust stat strip */
.sec-strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden; background:#fff; box-shadow:var(--shadow-sm); margin-top:48px; }
.sec-strip .cell{ padding:26px 28px; border-right:1px solid var(--line-2); }
.sec-strip .cell:last-child{ border-right:0; }
.sec-strip .sn{ font-size:30px; font-weight:700; letter-spacing:-0.03em; color:var(--blue); }
.sec-strip .sl{ font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.05em;
  color:var(--muted); margin-top:8px; }

/* pillars grid */
.sec-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.sec-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:28px;
  box-shadow:var(--shadow-sm); }
.sec-ic{ width:46px; height:46px; border-radius:12px; background:var(--blue-tint); color:var(--blue);
  display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.sec-ic svg{ width:24px; height:24px; }
.sec-card h3{ font-size:18px; font-weight:600; letter-spacing:-0.015em; }
.sec-card p{ color:var(--muted); font-size:14.5px; line-height:1.6; margin:10px 0 0; }
.sec-card ul{ margin:14px 0 0; padding:0; list-style:none; display:flex; flex-direction:column; gap:8px; }
.sec-card ul li{ position:relative; padding-left:22px; font-size:13.5px; color:var(--ink-2); line-height:1.5; }
.sec-card ul li::before{ content:""; position:absolute; left:2px; top:7px; width:11px; height:7px;
  border-left:2px solid var(--blue); border-bottom:2px solid var(--blue); transform:rotate(-45deg); }

/* compliance / residency band */
.sec-band{ background:var(--navy); color:#fff; }
.sec-band .wrap{ padding:74px var(--gutter); }
.sec-residency{ display:grid; grid-template-columns:1.1fr 1fr; gap:48px; align-items:center; }
.sec-residency h2{ color:#fff; font-size:clamp(28px,3vw,40px); letter-spacing:-0.028em; max-width:16ch; }
.sec-residency p{ color:#aebbd9; font-size:17px; line-height:1.6; margin-top:18px; max-width:46ch; }
.sec-loc{ display:flex; flex-direction:column; gap:12px; }
.sec-loc .loc{ display:flex; align-items:center; gap:14px; background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:18px 20px; }
.sec-loc .loc .pin{ width:38px; height:38px; border-radius:10px; background:rgba(127,176,255,.16);
  color:#7FB0FF; display:flex; align-items:center; justify-content:center; flex:none; }
.sec-loc .loc .pin svg{ width:20px; height:20px; }
.sec-loc .loc .lt{ font-weight:600; font-size:15px; }
.sec-loc .loc .ls{ color:#8da0c6; font-size:13px; margin-top:2px; }

/* compliance chips */
.sec-comply{ display:flex; flex-wrap:wrap; gap:12px; margin-top:34px; }
.sec-comply .chip{ display:inline-flex; align-items:center; gap:9px; height:42px; padding:0 18px;
  border-radius:11px; background:#fff; border:1px solid var(--line); font-weight:600; font-size:14px;
  color:var(--ink-2); box-shadow:var(--shadow-sm); }
.sec-comply .chip svg{ width:17px; height:17px; color:var(--blue); }

/* disclosure CTA */
.sec-disclose{ background:var(--bg-soft); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:40px 44px; display:grid; grid-template-columns:1fr auto; gap:28px; align-items:center; }
.sec-disclose h3{ font-size:23px; letter-spacing:-0.02em; }
.sec-disclose p{ color:var(--muted); font-size:15.5px; line-height:1.6; margin:10px 0 0; max-width:58ch; }

@media (max-width:860px){
  .sec-strip{ grid-template-columns:1fr 1fr; }
  .sec-strip .cell:nth-child(2){ border-right:0; }
  .sec-strip .cell:nth-child(1),.sec-strip .cell:nth-child(2){ border-bottom:1px solid var(--line-2); }
  .sec-grid{ grid-template-columns:1fr; }
  .sec-residency{ grid-template-columns:1fr; gap:32px; }
  .sec-disclose{ grid-template-columns:1fr; }
}
