/* ============================================================
   VENTRAX — sub-page styles (legal, about, careers, press)
   Loaded AFTER ../styles.css, which provides tokens + nav/footer/btn.
   ============================================================ */

/* nav is fixed; push content below it. Keep nav readable on white. */
.nav{ background:color-mix(in oklab, var(--bg) 82%, transparent);
  -webkit-backdrop-filter:blur(18px) saturate(160%); backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid var(--line); }
.subpage{ padding-top:74px; position:relative; z-index:1; }

/* ---------- page hero ---------- */
.page-hero{ border-bottom:1px solid var(--line); padding-block:clamp(54px,7vw,92px) clamp(36px,4vw,52px); }
.page-hero .eyebrow{ margin-bottom:20px; }
.page-hero h1{ font-family:var(--font-display); font-weight:600; letter-spacing:-.025em; line-height:1.02;
  font-size:clamp(34px,5vw,60px); margin:0; text-wrap:balance; }
.page-hero .page-sub{ margin-top:20px; max-width:60ch; }
.page-meta{ margin-top:26px; display:flex; gap:24px; flex-wrap:wrap; font-family:var(--font-mono);
  font-size:12px; letter-spacing:.04em; color:var(--ink-3); }
.page-meta b{ color:var(--ink-2); font-weight:500; }

/* ---------- note banner ---------- */
.note-banner{ display:flex; gap:13px; align-items:flex-start; margin-top:30px; padding:16px 18px;
  border:1px solid var(--line-2); border-radius:12px; background:color-mix(in oklab,var(--accent) 5%, var(--panel));
  font-size:14px; color:var(--ink-2); line-height:1.5; max-width:70ch; }
.note-banner .nb-dot{ flex:none; width:8px; height:8px; border-radius:50%; background:var(--accent); margin-top:7px;
  box-shadow:0 0 0 4px color-mix(in oklab,var(--accent) 16%, transparent); }

/* ============================================================
   LEGAL DOC LAYOUT (privacy / terms)
   ============================================================ */
.doc{ display:grid; grid-template-columns:236px 1fr; gap:clamp(32px,5vw,72px); padding-block:clamp(44px,5vw,68px) clamp(80px,9vw,120px); align-items:start; }
.doc-toc{ position:sticky; top:100px; align-self:start; }
.doc-toc .toc-label{ font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); margin-bottom:16px; }
.doc-toc a{ display:block; font-size:13.5px; color:var(--ink-3); padding:7px 0 7px 14px; border-left:2px solid var(--line); transition:color .2s, border-color .2s; line-height:1.35; }
.doc-toc a:hover{ color:var(--ink); }
.doc-toc a.active{ color:var(--ink); border-left-color:var(--accent); font-weight:500; }

.doc-body{ max-width:72ch; }
.doc-body section{ scroll-margin-top:100px; padding-bottom:38px; }
.doc-body section + section{ border-top:1px solid var(--line); padding-top:38px; }
.doc-body h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(20px,2.2vw,26px); letter-spacing:-.01em; margin:0 0 16px; display:flex; gap:14px; align-items:baseline; }
.doc-body h2 .s-n{ font-family:var(--font-mono); font-size:14px; color:var(--accent); font-weight:500; }
.doc-body h3{ font-family:var(--font-display); font-weight:600; font-size:16px; margin:24px 0 8px; }
.doc-body p{ color:var(--ink-2); font-size:15.5px; line-height:1.65; margin:0 0 14px; text-wrap:pretty; }
.doc-body ul{ margin:0 0 14px; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:10px; }
.doc-body li{ position:relative; padding-left:24px; color:var(--ink-2); font-size:15px; line-height:1.55; }
.doc-body li::before{ content:""; position:absolute; left:2px; top:9px; width:8px; height:8px; border:1.5px solid var(--accent); border-radius:2px; transform:rotate(45deg); }
.doc-body a.inline{ color:var(--accent); border-bottom:1px solid color-mix(in oklab,var(--accent) 40%, transparent); }

/* ============================================================
   ABOUT
   ============================================================ */
.section-block{ padding-block:clamp(56px,7vw,96px); border-bottom:1px solid var(--line); }
.about-lead{ font-family:var(--font-display); font-weight:500; letter-spacing:-.02em; line-height:1.22;
  font-size:clamp(22px,2.8vw,34px); max-width:24ch; text-wrap:balance; }
.about-lead em{ font-style:normal; color:var(--accent); }
.about-cols{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,60px); margin-top:36px; }
.about-cols p{ color:var(--ink-2); font-size:15.5px; line-height:1.65; }
.prod-mini{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:46px; }
.pm{ border:1px solid var(--line); border-radius:14px; padding:24px; background:var(--panel); }
.pm .pm-dot{ width:10px; height:10px; border-radius:50%; background:var(--brand); margin-bottom:16px; }
.pm h4{ font-family:var(--font-display); font-weight:600; font-size:19px; margin:0 0 4px; color:var(--brand); }
.pm .pm-cat{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.pm p{ margin:12px 0 0; font-size:13.5px; color:var(--ink-2); line-height:1.55; }

.stat-row{ display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--line); gap:1px; margin-top:10px; }
.stat-row .sc{ background:var(--bg); padding:28px 24px; }
.stat-row .sc b{ font-family:var(--font-display); font-weight:600; font-size:clamp(26px,3vw,38px); letter-spacing:-.02em; display:block; }
.stat-row .sc span{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); margin-top:10px; display:block; }

/* ============================================================
   CAREERS
   ============================================================ */
.roles{ margin-top:14px; border-top:1px solid var(--line); }
.role{ display:grid; grid-template-columns:1.4fr 1fr auto; gap:24px; align-items:center; padding:24px 6px; border-bottom:1px solid var(--line); transition:padding .3s; cursor:pointer; }
.role:hover{ padding-left:16px; }
.role .r-title{ font-family:var(--font-display); font-weight:600; font-size:clamp(17px,1.8vw,21px); letter-spacing:-.01em; }
.role .r-title span{ display:block; font-family:var(--font-mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); margin-top:6px; font-weight:400; }
.role .r-meta{ font-family:var(--font-mono); font-size:12.5px; color:var(--ink-2); letter-spacing:.02em; }
.role .r-arr{ width:36px; height:36px; border:1px solid var(--line-2); border-radius:50%; display:grid; place-items:center; color:var(--ink-2); transition:background .3s,color .3s,border-color .3s,transform .3s; }
.role:hover .r-arr{ background:var(--accent); color:#fff; border-color:var(--accent); transform:rotate(-45deg); }
.values{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:40px; }
.value h4{ font-family:var(--font-display); font-weight:600; font-size:18px; margin:0 0 10px; }
.value .v-n{ font-family:var(--font-mono); font-size:12px; color:var(--accent); }
.value p{ color:var(--ink-2); font-size:14.5px; line-height:1.55; margin:8px 0 0; }

/* ============================================================
   PRESS
   ============================================================ */
.facts{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; margin-top:10px; }
.fact{ background:var(--bg); padding:22px 24px; }
.fact dt{ font-family:var(--font-mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.fact dd{ margin:8px 0 0; font-size:15.5px; color:var(--ink); font-weight:500; }
.assets-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:14px; }
.asset-card{ border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--panel); }
.asset-prev{ height:130px; display:grid; place-items:center; border-bottom:1px solid var(--line); }
.asset-prev.light{ background:var(--bg-2); }
.asset-prev.dark{ background:#0E0E12; }
.asset-meta{ padding:16px 18px; display:flex; align-items:center; justify-content:space-between; }
.asset-meta b{ font-size:14px; font-weight:600; }
.asset-meta span{ font-family:var(--font-mono); font-size:10.5px; color:var(--ink-3); letter-spacing:.04em; }

/* ---------- responsive ---------- */
@media (max-width:860px){
  .doc{ grid-template-columns:1fr; }
  .doc-toc{ position:static; margin-bottom:8px; }
  .doc-toc a{ display:inline-block; border-left:0; padding:6px 12px; border:1px solid var(--line); border-radius:999px; margin:0 6px 6px 0; }
  .doc-toc a.active{ border-color:var(--accent); }
  .about-cols,.prod-mini,.values,.assets-grid{ grid-template-columns:1fr; }
  .stat-row,.facts{ grid-template-columns:1fr 1fr; }
  .role{ grid-template-columns:1fr auto; }
  .role .r-meta{ display:none; }
}
