/* ===========================================================================
   Prosecution Workbench — public marketing site
   Aesthetic: clean, spacious, modern-sans (Euclid-inspired), with PW's soul:
   serif only for quoted document text, mono anchors, verified/caution semantics.
   One stylesheet shared by every page. Dependency-free.
   =========================================================================== */

:root{
  /* surface */
  --bg:#ffffff;
  --panel:#f6f7f9;
  --panel-2:#eef1f4;
  --ink:#14161b;
  --ink-2:#2c313b;
  --muted:#5b6573;
  --faint:#8a93a3;
  --line:#e7e9ee;
  --line-2:#d6dae1;

  /* brand */
  --navy:#1b2845;
  --navy-700:#111a30;
  --accent:#2f54eb;        /* interactive blue, used sparingly */
  --accent-tint:#eef2ff;

  /* semantics (the verdict spectrum — the product's heart) */
  --verified:#2f7a55;
  --verified-bg:#e7f3ec;
  --mark:#cfe8d8;
  --caution:#9c5a26;
  --caution-bg:#f9f0e6;
  --danger:#8b2020;

  /* type */
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --serif:"Source Serif 4",Georgia,"Times New Roman",serif;
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;

  --maxw:1180px;
  --radius:10px;
  --radius-sm:7px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--bg);
  color:var(--ink-2);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--mark);color:#11271a}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}

/* ---------- type primitives ---------- */
h1,h2,h3{color:var(--ink);font-weight:600;letter-spacing:-0.02em;line-height:1.08}
.eyebrow{
  font-family:var(--mono);font-size:12px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}
.eyebrow.muted-eyebrow{color:var(--faint)}
.lede{font-size:20px;line-height:1.6;color:var(--ink-2);max-width:36em}
.muted{color:var(--muted)}
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}
.rule{height:1px;background:var(--line);border:0;margin:0}
strong,b{color:var(--ink);font-weight:600}

/* ---------- header / nav ---------- */
header.site{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.82);
  backdrop-filter:saturate(1.4) blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;gap:30px;height:68px}
.brand{display:flex;align-items:center;gap:11px;font-weight:600;font-size:17px;color:var(--ink);letter-spacing:-.01em}
.brand-seal{width:30px;height:30px;flex:none}
.nav-links{display:flex;gap:28px;margin-left:8px}
.nav-links a{font-size:15px;color:var(--muted);font-weight:500;transition:color .15s}
.nav-links a:hover,.nav-links a[aria-current]{color:var(--ink)}
.nav-spacer{flex:1}
.nav-login{font-size:15px;color:var(--muted);font-weight:500}
.nav-login:hover{color:var(--ink)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:8px;white-space:nowrap;cursor:pointer;
  font-family:var(--sans);font-size:15px;font-weight:550;
  padding:10px 18px;border-radius:var(--radius-sm);border:1px solid transparent;
  transition:transform .14s ease,box-shadow .2s ease,background .15s,border-color .15s,color .15s;
}
.btn-arrow{transition:transform .18s ease}
.btn:hover .btn-arrow{transform:translateX(3px)}
.btn--primary{background:var(--navy);color:#fff;box-shadow:0 1px 2px rgba(20,22,27,.18)}
.btn--primary:hover{background:var(--navy-700);transform:translateY(-1px);box-shadow:0 10px 24px -12px rgba(27,40,69,.7)}
.btn--ghost{color:var(--ink);border-color:var(--line-2);background:#fff}
.btn--ghost:hover{border-color:var(--ink);background:#fff}
.btn--lg{padding:13px 24px;font-size:16px}
.btn--light{background:#fff;color:var(--navy)}
.btn--light:hover{background:#f1f3f8;transform:translateY(-1px)}
.btn--on-ink{border-color:rgba(255,255,255,.28);color:#fff;background:transparent}
.btn--on-ink:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55)}

/* ---------- sections ---------- */
section{padding:clamp(64px,9vw,108px) 0}
.section--panel{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section--tight{padding:clamp(48px,6vw,72px) 0}
.sec-head{max-width:42rem;margin-bottom:54px}
.sec-head h2{font-size:clamp(28px,3.7vw,42px);margin-top:14px}
.sec-head p{margin-top:18px;font-size:18px;color:var(--muted)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- hero ---------- */
.hero{padding:clamp(56px,8vw,96px) 0 clamp(48px,7vw,84px)}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:56px;align-items:center}
.hero h1{font-size:clamp(40px,5.6vw,68px);letter-spacing:-.03em;margin:20px 0 22px}
.hero h1 .alt{color:var(--accent)}
.hero .lede b{color:var(--ink)}
.chain{
  margin:22px 0 2px;font-family:var(--mono);font-size:12.5px;color:var(--muted);
  display:flex;flex-wrap:wrap;gap:6px 4px;align-items:center;
}
.chain b{color:var(--ink);font-weight:500}
.chain i{color:var(--accent);font-style:normal}
.cta-row{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.trust-line{
  margin-top:26px;font-family:var(--mono);font-size:12.5px;color:var(--muted);
  display:flex;align-items:center;gap:9px;flex-wrap:wrap;
}
.dot{width:7px;height:7px;border-radius:50%;background:var(--verified);box-shadow:0 0 0 3px rgba(47,122,85,.16);flex:none}

/* ---------- provenance card (signature visual) ---------- */
.prov{
  background:#fff;border:1px solid var(--line-2);border-radius:14px;
  box-shadow:0 1px 0 #fff inset,0 28px 60px -34px rgba(20,22,27,.4),0 2px 8px -4px rgba(20,22,27,.12);
  overflow:hidden;position:relative;
}
.prov-top{display:flex;align-items:center;gap:9px;padding:13px 16px;border-bottom:1px solid var(--line);background:linear-gradient(#fff,#fbfcfd)}
.prov-tag{font-family:var(--mono);font-size:11px;font-weight:500;padding:3px 8px;border-radius:5px;border:1px solid var(--line-2);color:var(--muted);background:#fff}
.prov-tag.basis{color:#fff;background:var(--navy);border-color:var(--navy)}
.prov-verdict{margin-left:auto;font-family:var(--mono);font-size:11px;font-weight:500;color:var(--caution);padding:3px 10px;border-radius:20px;border:1px solid #e3c39e;background:var(--caution-bg)}
.prov-body{padding:18px}
.prov-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-bottom:7px}
.prov-claim{font-family:var(--serif);font-size:17px;line-height:1.45;color:var(--ink);margin-bottom:16px}
.prov-quote{font-family:var(--serif);font-size:15px;line-height:1.6;background:#fafbfc;border-left:2px solid var(--accent);padding:11px 14px;border-radius:0 8px 8px 0;color:var(--ink-2)}
.prov-quote mark{background:var(--mark);color:#11271a;padding:.5px 2px;border-radius:3px}
.prov-foot{display:flex;align-items:center;gap:8px;padding:12px 18px;border-top:1px solid var(--line);background:#fafbfc;font-family:var(--mono);font-size:11.5px;color:var(--muted);flex-wrap:wrap}
.prov-verified{margin-left:auto;display:inline-flex;align-items:center;gap:6px;color:var(--verified);font-weight:500}
.prov-verified svg{width:13px;height:13px}
.prov-note{font-family:var(--mono);font-size:10px;text-align:center;padding:8px;color:var(--faint);border-top:1px dashed var(--line);letter-spacing:.04em;text-transform:uppercase}
.anchor{font-family:var(--mono);padding:2px 7px;border-radius:5px;background:var(--panel-2);color:var(--ink-2);border:1px solid var(--line)}
.ghost-anchor{position:absolute;font-family:var(--mono);font-size:12px;color:var(--line-2);user-select:none;z-index:-1}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.step{padding:26px 22px;border-right:1px solid var(--line);position:relative}
.step:last-child{border-right:0}
.step .n{font-family:var(--mono);font-size:12px;color:var(--accent);font-weight:500}
.step h3{font-size:17px;margin:14px 0 8px}
.step p{font-size:14.5px;color:var(--muted);line-height:1.55}

/* ---------- generic card grid ---------- */
.grid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;padding:30px 28px 32px;transition:background .2s}
.card:hover{background:#fcfdfe}
.card .ix{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.06em}
.card h3{font-size:21px;margin:15px 0 10px}
.card p{font-size:15.5px;color:var(--muted);line-height:1.62}
.card .meta{margin-top:18px;display:flex;gap:7px;flex-wrap:wrap}
.pill{font-family:var(--mono);font-size:11.5px;color:var(--muted);padding:3px 9px;border:1px solid var(--line-2);border-radius:20px;background:#fff}
.pill.basis{color:var(--navy);border-color:#c9d0e6;background:#f3f5fb}

/* ---------- doctrine / credibility band (no fake metrics) ---------- */
.band{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;align-items:stretch}
.band-item{flex:1 1 200px;min-width:180px;border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px;background:#fff;text-align:left}
.band-item .k{font-family:var(--mono);font-size:12px;color:var(--accent);letter-spacing:.06em}
.band-item .v{display:block;margin-top:10px;font-size:16px;color:var(--ink);font-weight:550;line-height:1.4}
.band-item p{margin-top:7px;font-size:14px;color:var(--muted)}

/* ---------- claim-chart row mock ---------- */
.chart{border:1px solid var(--line-2);border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 18px 40px -30px rgba(20,22,27,.35)}
.chart-head{display:grid;grid-template-columns:1.1fr 1.4fr;background:var(--panel);border-bottom:1px solid var(--line);font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.chart-head>span{padding:11px 16px}
.chart-head>span+span{border-left:1px solid var(--line)}
.chart-row{display:grid;grid-template-columns:1.1fr 1.4fr;border-bottom:1px solid var(--line)}
.chart-row:last-child{border-bottom:0}
.chart-lim{padding:15px 16px;background:#fcfdfe;border-right:1px solid var(--line);font-family:var(--serif);font-size:14.5px;color:var(--ink);line-height:1.45}
.chart-map{padding:15px 16px}
.chart-map .vchip{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:2px 7px;border-radius:4px;margin-bottom:8px}
.vchip.disclosed{background:var(--accent-tint);color:var(--navy)}
.vchip.arguable{background:#e3eef5;color:#234a60}
.vchip.missing{background:var(--verified-bg);color:#0b5233}
.chart-map .q{font-family:var(--serif);font-size:13.5px;color:var(--ink-2);line-height:1.5}
.chart-map .src{margin-top:8px;font-family:var(--mono);font-size:11px;color:var(--muted);display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.chart-row.flag .chart-lim{box-shadow:inset 4px 0 0 var(--verified)}

/* ---------- rejection table mock ---------- */
.rtable{width:100%;border-collapse:collapse;font-size:14px;border:1px solid var(--line-2);border-radius:12px;overflow:hidden}
.rtable th{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);text-align:left;padding:12px 14px;background:var(--panel);border-bottom:1px solid var(--line)}
.rtable td{padding:13px 14px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink-2)}
.rtable tr:last-child td{border-bottom:0}
.basis-pill{font-family:var(--mono);font-size:11px;font-weight:600;color:#fff;background:var(--navy);padding:2px 8px;border-radius:5px}
.basis-pill.final{background:var(--danger)}

/* ---------- strategy meters ---------- */
.strat{display:flex;flex-direction:column;gap:14px}
.strat-row{display:grid;grid-template-columns:140px 1fr;gap:16px;align-items:center}
.strat-row .lab{font-size:13.5px;color:var(--ink)}
.meter{height:7px;border-radius:20px;background:var(--panel-2);overflow:hidden}
.meter-fill{height:100%;border-radius:20px;background:var(--navy)}
.meter-fill.warn{background:var(--caution)}
.meter-fill.good{background:var(--verified)}

/* ---------- guardrails (ink section) ---------- */
.section--ink{background:var(--navy);color:#d9deea;border:0}
.section--ink h2{color:#fff}
.section--ink .eyebrow{color:#93a2c8}
.guard-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:40px}
.gcol{border-top:1px solid rgba(255,255,255,.18);padding-top:18px}
.gcol .x{font-family:var(--mono);font-size:13px;color:#9db0d8;margin-bottom:10px}
.gcol p{font-size:14.5px;color:#c4ccdd;line-height:1.55}
.gcol b{color:#fff}

/* ---------- "how it works" stages ---------- */
.stage{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start;padding:clamp(40px,6vw,68px) 0;border-top:1px solid var(--line)}
.stage:first-of-type{border-top:0}
.stage-n{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:500}
.stage h3{font-size:clamp(22px,2.6vw,30px);margin:14px 0 16px}
.stage-body p{color:var(--muted);font-size:16px}
.stage-body p+p{margin-top:14px}
.stage-aside{position:sticky;top:96px}

/* ---------- interior page hero ---------- */
.page-hero{padding:clamp(56px,7vw,84px) 0 clamp(32px,4vw,44px);border-bottom:1px solid var(--line)}
.page-hero h1{font-size:clamp(34px,4.6vw,54px);letter-spacing:-.03em;margin:16px 0 18px;max-width:18em}
.page-hero .lede{font-size:19px;color:var(--muted)}
.breadcrumb{font-family:var(--mono);font-size:12px;color:var(--faint);letter-spacing:.04em}
.breadcrumb a:hover{color:var(--ink)}

/* ---------- prose blocks ---------- */
.prose{max-width:42rem}
.prose h3{font-size:21px;margin:36px 0 12px}
.prose h3:first-child{margin-top:0}
.prose p{color:var(--ink-2);margin-bottom:16px}
.prose ul{margin:0 0 18px 0;padding-left:0;list-style:none}
.prose li{position:relative;padding-left:24px;margin-bottom:11px;color:var(--ink-2)}
.prose li::before{content:"";position:absolute;left:4px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--accent)}
.prose li.no::before{background:var(--danger)}
.prose li.yes::before{background:var(--verified)}

/* ---------- request-access form ---------- */
.form{display:grid;gap:18px;max-width:34rem}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13.5px;font-weight:550;color:var(--ink)}
.field .hint{font-size:12.5px;color:var(--faint)}
.field input,.field textarea,.field select{
  font-family:var(--sans);font-size:15px;color:var(--ink);background:#fff;
  border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:11px 13px;width:100%;
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
.field textarea{min-height:120px;resize:vertical}
.form-note{font-family:var(--mono);font-size:12px;color:var(--faint);display:flex;gap:8px;align-items:flex-start;line-height:1.5}

/* ---------- CTA ---------- */
.cta{text-align:center}
.cta h2{font-size:clamp(30px,4.4vw,52px);letter-spacing:-.03em;max-width:17em;margin:16px auto 14px;line-height:1.05}
.cta h2 .alt{color:var(--accent)}
.cta p{max-width:32em;margin:0 auto 28px;color:var(--muted);font-size:18px}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);padding:56px 0 48px;background:var(--panel)}
.foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
.foot-brand .brand{margin-bottom:14px}
.foot-brand p{font-size:14px;color:var(--muted);max-width:24em}
.foot-col h4{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);font-weight:500;margin-bottom:14px}
.foot-col a{display:block;font-size:14.5px;color:var(--muted);margin-bottom:10px;transition:color .15s}
.foot-col a:hover{color:var(--ink)}
.foot-base{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:40px;padding-top:22px;border-top:1px solid var(--line-2)}
.foot-base small{font-family:var(--mono);font-size:11.5px;color:var(--faint);letter-spacing:.03em}
.foot-base .spacer{flex:1}

/* ---------- load reveal ---------- */
.reveal{opacity:0;transform:translateY(14px);animation:rise .8s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{to{opacity:1;transform:none}}
.d1{animation-delay:.04s}.d2{animation-delay:.12s}.d3{animation-delay:.2s}
.d4{animation-delay:.3s}.d5{animation-delay:.4s}.d6{animation-delay:.5s}

/* ---------- responsive ---------- */
@media (max-width:1000px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .steps{grid-template-columns:repeat(2,1fr)}
  .step:nth-child(2n){border-right:0}
  .step{border-bottom:1px solid var(--line)}
  .guard-grid{grid-template-columns:1fr 1fr;gap:26px}
  .stage{grid-template-columns:1fr;gap:24px}
  .stage-aside{position:static}
  .foot{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  body{font-size:16px}
  .nav-links{display:none}
  .grid--3,.grid--2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .step{border-right:0}
  .guard-grid{grid-template-columns:1fr}
  .chart-head,.chart-row{grid-template-columns:1fr}
  .chart-lim{border-right:0;border-bottom:1px solid var(--line)}
  .strat-row{grid-template-columns:110px 1fr}
  .foot{grid-template-columns:1fr 1fr}
}
@media (max-width:480px){
  .wrap{padding:0 20px}
  .foot{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{animation:none;opacity:1;transform:none}
  .btn,.btn-arrow{transition:none}
}
