/* Shared styles for Labhouse legal pages — minimal, premium, on-brand */

:root{
  --bg:#08090c;
  --bg-2:#0c0e13;
  --ink:#f5f6f8;
  --ink-2:#c8ccd3;
  --ink-3:#8b909a;
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);
  --blue:#428CFF;
  --blue-soft:rgba(66,140,255,.12);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:'Inter',ui-sans-serif,system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{font-size:16px;line-height:1.65;letter-spacing:-.005em;font-feature-settings:'ss01','cv11'}

a{color:var(--blue);text-decoration:none;transition:color .2s, opacity .2s}
a:hover{opacity:.8}

/* Subtle ambient backdrop */
.bg-fx{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-fx::before{content:"";position:absolute;inset:-200px;background:
  radial-gradient(70% 60% at 18% 12%, rgba(66,140,255,.07), transparent 60%),
  radial-gradient(60% 60% at 86% 88%, rgba(66,140,255,.05), transparent 60%);
  filter:blur(20px)}
.bg-fx::after{content:"";position:absolute;inset:0;
  background:radial-gradient(transparent 0,transparent 50%,#06070a 100%)}

/* Layout */
.legal-page{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}
.wrap{max-width:820px;margin:0 auto;padding:0 28px;width:100%}

/* Nav — floating glass pill (mirrors homepage) */
nav.top{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:50;
  display:flex;align-items:center;gap:18px;
  padding:10px 14px 10px 18px;
  background:rgba(0,0,0,.72);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line-2);border-radius:999px;
  box-shadow:0 10px 40px -10px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05);
}
nav.top .logo{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
nav.top .logo img{height:26px;display:block}
nav.top ul{display:flex;gap:6px;list-style:none;margin:0;padding:0;flex-wrap:nowrap}
nav.top ul li{white-space:nowrap}
nav.top a.lnk{font-size:13px;color:var(--ink-2);padding:8px 14px;border-radius:999px;transition:.25s;white-space:nowrap}
nav.top a.lnk:hover{color:var(--ink);background:rgba(255,255,255,.05);opacity:1}
nav.top a.cta{
  font-size:13px;font-weight:600;padding:9px 16px;border-radius:999px;
  background:var(--ink);color:#000;transition:.25s;display:inline-flex;align-items:center;gap:6px;
  white-space:nowrap;flex:0 0 auto;
}
nav.top a.cta:hover{background:#428CFF;color:#fff;box-shadow:0 0 28px rgba(66,140,255,.55);opacity:1}
nav.top a.cta svg{transition:.25s}
nav.top a.cta:hover svg{transform:translate(2px,-2px)}

/* Back-to-home pill — floating outside the nav (top-left corner) */
a.back-pill{
  position:fixed;top:24px;left:24px;z-index:49;
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;padding:9px 14px 9px 12px;border-radius:999px;
  background:rgba(0,0,0,.6);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--line-2);color:var(--ink-2);
  transition:.25s;
}
a.back-pill:hover{color:#fff;border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.06);opacity:1;transform:translateX(-2px)}
a.back-pill svg{transition:.25s}

@media (min-width:641px) and (max-width:1024px){
  nav.top{gap:12px;padding:8px 8px 8px 16px;max-width:calc(100vw - 24px)}
  nav.top ul{gap:2px}
  nav.top a.lnk{font-size:12.5px;padding:7px 10px}
  nav.top a.cta{font-size:12.5px;padding:8px 14px;white-space:nowrap}
  nav.top .logo img{height:22px}
}

@media (max-width:640px){
  nav.top ul{display:none}
  a.back-pill{top:auto;bottom:18px;left:50%;transform:translateX(-50%)}
  a.back-pill:hover{transform:translateX(-50%) translateY(-2px)}
}

/* Push hero below the floating pill */
header.legal-hero{padding-top:130px !important}

/* Hero */
header.legal-hero{padding:84px 0 32px}
header.legal-hero .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--blue);font-size:13px;font-weight:500;letter-spacing:.02em;
  padding:6px 14px;border-radius:999px;
  background:var(--blue-soft);
  border:1px solid rgba(66,140,255,.22);
}
header.legal-hero h1{
  font-size:clamp(40px,5.4vw,64px);line-height:1.04;letter-spacing:-.035em;
  margin:18px 0 14px;font-weight:700;
}
header.legal-hero .meta{color:var(--ink-3);font-size:14px;display:flex;gap:18px;flex-wrap:wrap;margin-top:10px}
header.legal-hero .meta span::before{content:"·";margin-right:18px;color:var(--line-2)}
header.legal-hero .meta span:first-child::before{content:"";margin:0}

/* Body content */
main.legal-body{flex:1;padding:24px 0 80px}
main.legal-body{counter-reset:section}
main.legal-body p{color:var(--ink-2);margin:0 0 18px;text-wrap:pretty}
main.legal-body strong{color:var(--ink);font-weight:600}
main.legal-body em{color:var(--ink-2);font-style:italic}

main.legal-body h2{
  font-size:22px;line-height:1.25;letter-spacing:.02em;text-transform:uppercase;
  margin:48px 0 16px;color:var(--ink);font-weight:700;
  padding-top:24px;border-top:1px solid var(--line);
  display:flex;align-items:baseline;gap:14px;
  counter-increment:section;counter-reset:sub;
}
main.legal-body h2 .n{display:none}
main.legal-body h2::before{
  content:counter(section) ".";
  color:var(--ink);font-weight:700;font-feature-settings:'tnum';
  font-size:22px;letter-spacing:0;text-transform:none;flex-shrink:0;min-width:28px;
}

/* Numbered sub-items: 1.1, 1.2 … */
main.legal-body ol.numbered{
  list-style:none;padding:0;margin:0 0 28px;
  display:flex;flex-direction:column;gap:18px;
}
main.legal-body ol.numbered > li{
  counter-increment:sub;
  padding-left:58px;position:relative;color:var(--ink-2);margin:0;
}
main.legal-body ol.numbered > li::before{
  content:counter(section) "." counter(sub);
  position:absolute;left:0;top:0;
  color:var(--blue);font-feature-settings:'tnum';font-size:14px;font-weight:500;
  letter-spacing:.02em;line-height:1.7;min-width:48px;
}
main.legal-body ol.numbered > li > p:first-child,
main.legal-body ol.numbered > li > h3:first-child{margin-top:0}
main.legal-body ol.numbered > li > *:last-child{margin-bottom:0}
/* Inner sub-lists inside a numbered <li> — styled as italic blue lower-roman, matching the defs list */
main.legal-body ol.numbered > li ol:not(.numbered),
main.legal-body ol.numbered > li ul{
  list-style:none;padding:0;margin:10px 0 0;
  display:flex;flex-direction:column;gap:12px;
  counter-reset:rom;
}
main.legal-body ol.numbered > li ol:not(.numbered) > li,
main.legal-body ol.numbered > li ul > li{
  counter-increment:rom;
  padding:0 0 0 38px;position:relative;margin:0;color:var(--ink-2);
}
main.legal-body ol.numbered > li ol:not(.numbered) > li::before,
main.legal-body ol.numbered > li ul > li::before{
  content:counter(rom,lower-roman) ".";
  position:absolute;left:0;top:0;
  color:var(--blue);font-style:italic;font-weight:600;
  font-feature-settings:'tnum';font-size:14px;line-height:1.7;
  letter-spacing:.02em;min-width:30px;
}
main.legal-body ol.numbered > li h3{margin:0 0 8px}
main.legal-body h2 .n{
  color:var(--blue);font-feature-settings:'tnum';font-size:14px;font-weight:500;
  letter-spacing:.04em;padding-top:4px;flex-shrink:0;min-width:36px;
}
main.legal-body h3{
  font-size:16px;line-height:1.4;color:var(--ink);font-weight:600;
  margin:28px 0 10px;letter-spacing:-.01em;
}

main.legal-body ol, main.legal-body ul{
  margin:0 0 18px;padding-left:22px;color:var(--ink-2);
}
main.legal-body ol > li, main.legal-body ul > li{margin-bottom:10px}
main.legal-body ol > li::marker{color:var(--ink-3);font-feature-settings:'tnum'}
main.legal-body ul > li::marker{color:var(--blue)}

main.legal-body .lead{
  font-size:17px;color:var(--ink-2);
  padding:20px 22px;border-radius:14px;
  background:rgba(255,255,255,.025);border:1px solid var(--line);
  margin-bottom:32px;
}

main.legal-body .defs{
  list-style:none;padding:0;margin:0 0 28px;counter-reset:def;
  display:flex;flex-direction:column;gap:18px;
}
main.legal-body .defs li{
  counter-increment:def;
  padding:0 0 0 58px;position:relative;margin:0;color:var(--ink-2);
}
main.legal-body .defs li::before{
  content:counter(def,lower-roman) ".";
  position:absolute;left:0;top:0;
  color:var(--blue);font-style:italic;font-weight:600;
  font-size:15px;line-height:1.7;min-width:48px;text-align:right;padding-right:10px;
}

/* Tables */
main.legal-body .table-wrap{
  margin:22px -8px 28px;
  border:1px solid var(--line);border-radius:14px;
  overflow-x:auto;overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  background:rgba(255,255,255,.015);
  position:relative;
}
main.legal-body .table-wrap table{min-width:640px}
main.legal-body table{width:100%;border-collapse:collapse;font-size:14px}
main.legal-body thead th{
  text-align:left;padding:14px 18px;
  background:rgba(255,255,255,.04);color:var(--ink);font-weight:600;font-size:12px;
  letter-spacing:.05em;text-transform:uppercase;
  border-bottom:1px solid var(--line);
}
main.legal-body tbody td{
  padding:18px;color:var(--ink-2);line-height:1.55;
  border-top:1px solid var(--line);vertical-align:top;
}
main.legal-body tbody tr:first-child td{border-top:none}
main.legal-body tbody td + td{border-left:1px solid var(--line)}

/* Footer */
footer.legal-footer{
  border-top:1px solid var(--line);
  padding:36px 28px;background:rgba(0,0,0,.3);
}
footer.legal-footer .inner{
  max-width:1320px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
  color:var(--ink-3);font-size:13px;
}
footer.legal-footer .links{display:flex;gap:22px;flex-wrap:wrap}
footer.legal-footer .links a{color:var(--ink-3);font-weight:500}
footer.legal-footer .links a:hover{color:#fff;opacity:1}

@media (max-width:720px){
  nav.top{padding:14px 18px}
  nav.top .back{padding:7px 12px;font-size:12px}
  header.legal-hero{padding:48px 0 24px}
  header.legal-hero h1{font-size:38px}
  .wrap{padding:0 20px}
  main.legal-body{padding:12px 0 60px}
  main.legal-body h2{font-size:19px;margin-top:36px;gap:10px}
  main.legal-body table{font-size:13px}
  main.legal-body tbody td{padding:14px}
  main.legal-body .table-wrap{margin-left:-12px;margin-right:-12px;border-left:0;border-right:0;border-radius:0}
  main.legal-body .table-wrap table{min-width:680px}
  main.legal-body ol.numbered > li{padding-left:46px}
  main.legal-body ol.numbered > li::before{font-size:13px;min-width:40px}
  footer.legal-footer .inner{flex-direction:column;align-items:flex-start;text-align:left}
}
