/* ─────────────────────────────────────────────────────────────────
   masoustraitance.fr · static site styles
   ----------------------------------------------------------------
   Tokens, layout primitives, components, animations, media queries.
   One file · loaded once · cached forever.
   ──────────────────────────────────────────────────────────────── */

/* ─── Tokens ─── */
:root {
  --bg:        #0A0F1A;
  --bg-2:      #0F1626;
  --bg-3:      #152033;
  --ink:       #EDE9DF;
  --ink-2:     rgba(237, 233, 223, .72);
  --ink-3:     rgba(237, 233, 223, .46);
  --ink-4:     rgba(237, 233, 223, .3);
  --rule:      rgba(237, 233, 223, .1);
  --rule-2:    rgba(237, 233, 223, .18);
  --accent:    #D97757;
  --accent-2:  #7A3A1E;
  --good:      #5BC68E;
  --danger:    #FF6B5C;

  --sans:      "Space Grotesk", "IBM Plex Sans", ui-sans-serif, system-ui, sans-serif;
  --mono:      "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --rad:       4px;
  --rad-lg:    6px;
  --rad-xl:    8px;
  --maxw:      1200px;
}

/* ─── Reset ─── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
  background-image:
    radial-gradient(ellipse 80% 50% at 80% -10%, rgba(217, 119, 87, .18), transparent 60%),
    radial-gradient(ellipse 60% 40% at 0% 10%, rgba(46, 125, 84, .07), transparent 60%);
}
a { color: inherit; text-decoration: none; cursor: pointer; }
p, h1, h2, h3, h4 { margin: 0; }
ul, ol { margin: 0; padding: 0; }
button { font: inherit; color: inherit; }
img, svg { display: block; max-width: 100%; }
input, textarea, select, button { font-family: inherit; }

/* ─── Layout primitives ─── */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }
.stack { display: grid; gap: var(--g, 16px); }
.row   { display: flex; gap: var(--g, 16px); }
.row-c { align-items: center; }
.row-b { align-items: baseline; }
.row-x { justify-content: space-between; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }

/* ─── Wordmark ─── */
.logo {
  font-family: var(--sans);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.015em;
  white-space: nowrap;
  position: relative;
}
.logo.sm { font-size: 17px; }
.logo i { font-style: normal; position: relative; }
.logo i::after {
  content: "";
  position: absolute;
  left: 0.18em; top: -0.1em;
  width: 0.22em; height: 0.22em;
  background: var(--accent);
  border-radius: 2px;
  transform: rotate(45deg);
}
.logo .tld { color: var(--ink-3); font-weight: 400; }

/* ─── Status & badges ─── */
.statusbar {
  padding: 10px 32px;
  border-bottom: 1px solid var(--rule);
  background: rgba(255,255,255,.015);
  font: 400 11.5px/1 var(--mono);
  color: var(--ink-3);
  display: flex; justify-content: space-between; align-items: center;
  letter-spacing: 0.02em;
  white-space: nowrap;
  overflow: hidden;
}
.statusbar > * { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent);
  box-shadow: 0 0 0 4px rgba(217,119,87,.18); display: inline-block; }
.beta-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 7px;
  border: 1px dashed var(--accent);
  color: var(--accent);
  font: 500 10.5px/1 var(--mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.beta-pill > span { width: 5px; height: 5px; background: var(--accent); border-radius: 50%; }

/* ─── Header ─── */
.hdr {
  padding: 22px 32px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid var(--rule);
}
.hdr .brand { display: flex; align-items: center; gap: 14px; }
.hdr nav { display: flex; gap: 22px; font: 500 13px/1 var(--sans); color: var(--ink-2); }
.hdr .ctas { display: flex; gap: 10px; }

.navlink {
  padding: 4px 6px;
  border-radius: 3px;
  transition: color .15s ease, background .15s ease;
}
.navlink:hover { color: var(--accent); }
.navlink.is-active { color: var(--accent); }

/* ─── Buttons ─── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-radius: var(--rad);
  font: 500 13px/1 var(--sans);
  letter-spacing: 0.005em;
  border: 1px solid transparent;
  background: transparent;
  cursor: pointer;
  white-space: nowrap;
  transition: transform .15s ease, filter .15s ease, box-shadow .2s ease, background .15s ease;
}
.btn.lg { padding: 13px 20px; font-size: 14px; }
.btn.xl { padding: 14px 22px; font-size: 14.5px; }
.btn:hover { filter: brightness(1.08); transform: translateY(-1px); }
.btn:active { transform: translateY(0); filter: brightness(.96); }

.btn-primary { background: var(--accent); color: #0A0F1A; font-weight: 600; }
.btn-primary:hover { box-shadow: 0 10px 30px rgba(217,119,87,.35); }

.btn-ghost { color: var(--ink); border-color: var(--rule-2); background: rgba(255,255,255,.02); }
.btn-ghost:hover { background: rgba(255,255,255,.06); border-color: rgba(237,233,223,.35); }

/* ─── Sections ─── */
.sect { padding: 80px 32px; }
.sect-sm { padding: 60px 32px; }
.sect-tight { padding: 40px 32px; }

.sect-head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 32px; margin-bottom: 32px;
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 12px;
}
.eyebrow.is-accent { color: var(--accent); }
.eyebrow > .pulse {
  width: 6px; height: 6px; background: var(--accent); border-radius: 50%;
}

.h1, .h1-xl { font-weight: 600; letter-spacing: -0.035em; line-height: .98; margin: 0; }
.h1 { font-size: 60px; }
.h1-xl { font-size: 72px; }
.h2 { font: 500 36px/1.1 var(--sans); letter-spacing: -0.025em; margin: 0; }
.h3 { font: 500 28px/1.15 var(--sans); letter-spacing: -0.02em; margin: 0; }
.lede { font-size: 17.5px; line-height: 1.55; color: var(--ink-2); margin: 0; max-width: 540px; }
.muted { color: var(--ink-2); }
.dim { color: var(--ink-3); }
.text-balance { text-wrap: balance; }
.text-accent { color: var(--accent); }
.text-good   { color: var(--good); }
.mono { font-family: var(--mono); }

/* ─── Caret (blinks) ─── */
.caret {
  display: inline-block; width: 8px; height: 1em;
  background: var(--accent);
  vertical-align: -0.15em;
  margin-left: 8px;
  animation: caret 1.1s steps(2, start) infinite;
}
@keyframes caret { 0%,50% { opacity: 1; } 50.01%,100% { opacity: 0; } }

/* ─── Hero stack ─── */
.hero { padding: 100px 32px 80px; }
.hero .cols { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }
.hero .lede { margin: 0 0 32px; }
.hero .ctas-row { display: flex; gap: 12px; margin-bottom: 36px; }
.tag {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 7px 11px;
  border: 1px solid var(--rule-2);
  border-radius: 999px;
  font: 500 11px/1 var(--mono);
  letter-spacing: 0.05em;
  color: var(--ink-2);
  margin-bottom: 28px;
}
.tag .gt { color: var(--accent); }

/* ─── Mini stats strip ─── */
.kv-strip {
  display: grid; grid-template-columns: repeat(3, 1fr);
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  overflow: hidden;
  background: rgba(255,255,255,.015);
}
.kv-strip .kv { padding: 14px 16px; }
.kv-strip .kv + .kv { border-left: 1px solid var(--rule); }
.kv-strip .kv .k { font: 500 10px/1 var(--mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.kv-strip .kv .v { font: 500 16px/1 var(--sans); margin-bottom: 5px; }
.kv-strip .kv .s { font: 400 11px/1 var(--mono); color: var(--accent); }

/* ─── Console panel ─── */
.console {
  background: linear-gradient(180deg, #0E1525 0%, #0A0F1A 100%);
  border: 1px solid var(--rule-2);
  border-radius: var(--rad-xl);
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.4), 0 0 0 1px rgba(217,119,87,.06);
}
.console-hd {
  padding: 10px 14px;
  background: rgba(255,255,255,.02);
  border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; gap: 8px;
  font: 400 11.5px/1 var(--mono);
  color: var(--ink-3);
}
.console-hd .light { width: 9px; height: 9px; border-radius: 50%; }
.console-hd .l-r { background: #FF5F57; }
.console-hd .l-y { background: #FEBC2E; }
.console-hd .l-g { background: #28C840; }
.console-hd .path { margin-left: 12px; }
.console-body { padding: 18px 20px; font: 400 13px/1.7 var(--mono); color: var(--ink-2); }
.console-body .cmd { color: var(--ink-3); }
.console-body .row3 { display: grid; grid-template-columns: auto 1fr auto auto; gap: 14px; padding: 2px 0; color: var(--ink); }
.console-body .ok  { color: var(--good); }
.console-body .wait { color: var(--accent); }
.console-body em { color: var(--accent); font-style: normal; }

/* ─── Pillars (illustrated cards) ─── */
.pillars { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.pillar {
  background: var(--bg-2);
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  overflow: hidden;
  display: flex; flex-direction: column;
  position: relative;
  transition: transform .2s ease, border-color .2s ease;
}
.pillar:hover { transform: translateY(-2px); border-color: rgba(217,119,87,.35); }
.pillar:hover::after {
  content: ""; position: absolute; inset: -1px; pointer-events: none;
  border-radius: inherit;
  box-shadow: 0 0 0 1px rgba(217,119,87,.4), 0 18px 50px rgba(0,0,0,.35);
}
.illu {
  position: relative;
  height: 132px;
  overflow: hidden;
  background: radial-gradient(ellipse at center top, rgba(217,119,87,.08), transparent 60%), #0B1322;
  border-bottom: 1px solid var(--rule);
}
.illu::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(to bottom, transparent 0 3px, rgba(255,255,255,.025) 3px 4px);
  pointer-events: none;
}
.pillar-body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.pillar-body .tag-mono {
  font: 500 10.5px/1 var(--mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3);
}
.pillar-body .title { font: 500 17px/1.25 var(--sans); letter-spacing: -0.012em; }
.pillar-body .desc  { font: 400 13px/1.6 var(--sans); color: var(--ink-2); margin: 0; }
.pillar-body .detail {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px dashed var(--rule-2);
  font: 400 10.5px/1.4 var(--mono);
  color: var(--ink-3);
}

/* ─── Loading bar (analysing system…) ─── */
.bar {
  position: relative;
  height: 6px; width: 80px;
  background: rgba(237,233,223,.06);
  border-radius: 3px;
  overflow: hidden;
}
.bar::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  animation: bar 2.4s linear infinite;
}
@keyframes bar { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }

/* ─── Human-review section ─── */
.review-card {
  position: relative;
  border: 1px solid var(--rule);
  border-radius: var(--rad-xl);
  background: radial-gradient(ellipse at 0% 0%, rgba(217,119,87,.08), transparent 55%), var(--bg-2);
  padding: 48px;
  overflow: hidden;
}
.review-card .cols { display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: start; }
.review-list {
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  background: linear-gradient(180deg, #0E1525, #0A0F1A);
  overflow: hidden;
}
.review-list .row {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 14px; align-items: baseline;
  padding: 12px 18px;
  border-top: 1px dashed var(--rule);
}
.review-list .row:first-child { border-top: 0; }
.review-list .flag { color: var(--accent); font: 500 11px/1 var(--mono); }
.review-list .title { font: 500 13.5px/1.3 var(--sans); color: var(--ink); letter-spacing: -.005em; }
.review-list .sub { font: 400 11.5px/1.45 var(--mono); color: var(--ink-3); margin-top: 3px; }
.tag-check {
  font: 500 9.5px/1 var(--mono);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--good);
  padding: 3px 6px;
  border: 1px solid rgba(91,198,142,.3);
  border-radius: 3px;
  background: rgba(91,198,142,.06);
}
.quote {
  border-left: 2px solid var(--accent);
  padding-left: 14px;
  font: 400 14px/1.55 var(--sans);
  color: var(--ink-2);
  font-style: italic;
}
.quote cite {
  display: block;
  margin-top: 8px;
  font: 400 12px/1 var(--mono);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-style: normal;
}

/* ─── Flow (donneur → ST → vault) ─── */
.flow {
  display: grid; grid-template-columns: 1fr 56px 1fr 56px 1fr;
  gap: 0; align-items: stretch;
}
.flow-node {
  background: var(--bg-2);
  border: 1px solid var(--rule-2);
  border-radius: var(--rad-lg);
  padding: 26px 26px 22px;
  display: flex; flex-direction: column; gap: 10px;
  min-height: 200px;
}
.flow-node .e { font: 500 10.5px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); }
.flow-node .t { font: 500 18px/1.25 var(--sans); letter-spacing: -.015em; }
.flow-node .d { font: 400 13.5px/1.55 var(--sans); color: var(--ink-2); margin: 0; }
.flow-node .tg {
  margin-top: auto;
  font: 500 10.5px/1 var(--mono); letter-spacing: .06em;
  color: var(--ink-2);
  padding: 5px 7px;
  border: 1px solid var(--rule);
  border-radius: 3px;
  width: max-content;
}
.flow-node.is-vault { background: var(--accent); border-color: var(--accent); color: #0A0F1A; }
.flow-node.is-vault .e { color: rgba(10,15,26,.6); }
.flow-node.is-vault .d { color: rgba(10,15,26,.75); }
.flow-node.is-vault .tg { color: rgba(10,15,26,.75); border-color: rgba(10,15,26,.18); }
.flow-link {
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.flow-link::before {
  content: ""; position: absolute; left: 0; right: 0; top: 50%;
  height: 1px; margin-top: -.5px;
  background: linear-gradient(to right, var(--rule) 50%, transparent 50%) 0 0 / 10px 1px repeat-x;
}
.flow-dot {
  position: relative; z-index: 2;
  width: 9px; height: 9px; background: var(--accent); border-radius: 50%;
  box-shadow: 0 0 0 5px rgba(217,119,87,.15);
  animation: pulse 2.4s ease-in-out infinite;
}
.flow-dot.delay { animation-delay: 1.2s; }
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.7); opacity: .5; }
}

/* ─── Law block (3 col) ─── */
.law {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  overflow: hidden;
}
.law-col { padding: 30px 28px; }
.law-col + .law-col { border-left: 1px solid var(--rule); }
.law-col.is-warn { background: rgba(217,119,87,.04); }
.law-col .h { font: 500 11px/1 var(--mono); color: var(--ink-3); margin-bottom: 14px; }
.law-col .t { font: 500 17px/1.3 var(--sans); margin-bottom: 10px; letter-spacing: -.01em; }
.law-col .d { font: 400 13.5px/1.6 var(--sans); color: var(--ink-2); margin: 0; }

/* ─── Sectors list ─── */
.sectors {
  background: var(--bg-2);
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  overflow: hidden;
}
.sectors .row {
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 22px; align-items: center;
  padding: 16px 22px;
  border-top: 1px solid var(--rule);
}
.sectors .row:first-child { border-top: 0; }
.sectors .row .num { font: 500 11px/1 var(--mono); color: var(--ink-3); }
.sectors .row .name { font: 500 14.5px/1.3 var(--sans); letter-spacing: -.005em; }
.sectors .row .docs { font: 400 12px/1.4 var(--mono); color: var(--ink-3); margin-top: 4px; }
.sectors .row .naf  { font: 500 11px/1 var(--mono); color: var(--accent); }

/* ─── CTA card ─── */
.cta {
  border: 1px solid var(--rule-2);
  border-radius: var(--rad-xl);
  background: radial-gradient(ellipse at 90% 100%, rgba(217,119,87,.18), transparent 55%), var(--bg-2);
  padding: 56px;
  display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center;
}

/* ─── Form ─── */
.form { display: grid; gap: 14px; }
.form .grid-pair { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form .grid-pair.alt { grid-template-columns: 1fr 220px; }
.form label { display: flex; align-items: baseline; justify-content: space-between;
  font: 500 10.5px/1 var(--mono);
  letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.form .err { color: var(--danger); display: none; }
.form input, .form textarea {
  width: 100%;
  padding: 11px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--rule-2);
  border-radius: var(--rad);
  color: var(--ink);
  font: 400 14px/1.4 var(--mono);
  outline: none;
  transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}
.form input:focus, .form textarea:focus {
  border-color: var(--accent);
  background: rgba(255,255,255,.06);
  box-shadow: 0 0 0 3px rgba(217,119,87,.15);
}
.form .field.is-error input,
.form .field.is-error textarea {
  border-color: var(--danger);
  background: rgba(255,107,92,.06);
}
.form .field.is-error .err { display: inline; }
.form .submit-row { display: flex; align-items: center; justify-content: space-between; }
.form .submit-row .meta { font: 400 11px/1.4 var(--mono); color: var(--ink-3); }

.form-success {
  border: 1px solid var(--accent);
  border-radius: var(--rad-lg);
  padding: 32px 30px;
  background: rgba(217,119,87,.06);
  display: none;
}
.form-success.is-on { display: grid; gap: 14px; animation: success-in .4s cubic-bezier(.2,.7,.3,1) both; }
.form-success .h { font: 500 11px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--accent); }
.form-success .t { font: 500 24px/1.2 var(--sans); letter-spacing: -.015em; }
.form-success .d { font: 400 14px/1.6 var(--sans); color: var(--ink-2); margin: 0; }
.form-success pre {
  margin: 0; padding: 12px 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--rule);
  border-radius: var(--rad);
  font: 400 12px/1.6 var(--mono);
  color: var(--ink-3);
  overflow: hidden;
}
@keyframes success-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* ─── Why-us list ─── */
.tmg-list { background: var(--bg-2); border: 1px solid var(--rule); border-radius: var(--rad-lg); padding: 8px 22px; }
.tmg-list .row {
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--rule);
}
.tmg-list .row:first-child { border-top: 0; }
.tmg-list .row .name { font: 500 14.5px/1.3 var(--sans); }
.tmg-list .row .scope { font: 400 12px/1.4 var(--mono); color: var(--ink-3); margin-top: 4px; }
.tmg-list .row .role { font: 500 10.5px/1 var(--mono); color: var(--accent); }

/* ─── Footer ─── */
.ftr { padding: 40px 32px 48px; border-top: 1px solid var(--rule); }
.ftr .row { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; }
.ftr .links { display: flex; gap: 24px; font: 400 12.5px/1.4 var(--sans); color: var(--ink-3); }
.ftr .anchor { position: relative; }
.ftr .anchor::after {
  content: ""; position: absolute; left: 0; right: 100%; bottom: -2px;
  height: 1px; background: var(--accent);
  transition: right .2s ease;
}
.ftr .anchor:hover::after { right: 0; }
.ftr .credit { margin-top: 10px; font: 400 12px/1.4 var(--mono); color: var(--ink-3); }

/* ─── Page-specific (security) ─── */
.sec-hero h1 { font-size: 60px; letter-spacing: -0.035em; line-height: .98; }
.crumb { font: 400 12px/1 var(--mono); color: var(--ink-3); letter-spacing: 0.04em; margin-bottom: 18px; }
.crumb .now { color: var(--ink-4); }
.kv-row {
  display: grid; grid-template-columns: 180px 1fr; gap: 16px;
  padding: 10px 0;
  border-top: 1px solid var(--rule);
  font: 400 13.5px/1.5 var(--sans);
  align-items: baseline;
}
.kv-row .k { font: 500 11px/1.4 var(--mono); letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); }
.kv-row .v { color: var(--ink); }

.sec-point {
  padding: 22px 24px;
  background: var(--bg-2);
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
}
.sec-point .k { font: 500 10.5px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }
.sec-point .v { font: 500 17px/1.25 var(--sans); letter-spacing: -.012em; color: var(--accent); margin-bottom: 10px; }
.sec-point .d { font: 400 13px/1.6 var(--sans); color: var(--ink-2); margin: 0; }

.code-block {
  background: var(--bg-2);
  border: 1px solid var(--rule);
  border-radius: var(--rad-lg);
  padding: 22px 24px;
  font: 400 12.5px/1.65 var(--mono);
  color: var(--ink-2);
  overflow: hidden;
}
.code-block .h { font: 500 10.5px/1 var(--mono); letter-spacing: .08em; color: var(--ink-3); margin-bottom: 12px; text-transform: uppercase; }
.code-block pre { margin: 0; font-family: inherit; white-space: pre-wrap; word-break: break-word; }

.tbl { width: 100%; border-collapse: collapse; font: 400 13.5px/1.55 var(--sans); }
.tbl thead tr { border-top: 1px solid var(--ink); border-bottom: 1px solid var(--rule); }
.tbl th { padding: 14px 0; text-align: left;
  font: 500 11px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); }
.tbl tbody tr { border-bottom: 1px solid var(--rule); }
.tbl td { padding: 16px 0; vertical-align: top; }
.tbl td.s { font: 500 14px/1.4 var(--sans); }
.tbl td.r { padding: 16px 14px; color: var(--ink-2); }
.tbl td.b { text-align: right; }
.status-pill {
  display: inline-block;
  font: 500 10.5px/1 var(--mono);
  letter-spacing: .06em; text-transform: uppercase;
  padding: 5px 8px;
  border-radius: 3px;
  border: 1px solid var(--rule-2);
  color: var(--ink-3);
}
.status-pill.is-good { color: var(--good); border-color: rgba(91,198,142,.3); background: rgba(91,198,142,.06); }

/* ─── Legal page tabs (CSS-only with radio inputs) ─── */
.legal-tabs { display: inline-flex; padding: 4px;
  background: var(--bg-2); border: 1px solid var(--rule); border-radius: var(--rad-lg); gap: 2px; }
.legal-tabs label {
  padding: 8px 14px; border-radius: var(--rad);
  font: 500 13px/1 var(--sans); color: var(--ink-2); cursor: pointer;
  letter-spacing: 0.01em;
}
.legal-tab-input { position: absolute; opacity: 0; pointer-events: none; }
.legal-pane { display: none; }
#tab-mentions:checked ~ .legal-tabs label[for=tab-mentions],
#tab-confid:checked ~ .legal-tabs label[for=tab-confid],
#tab-cookies:checked ~ .legal-tabs label[for=tab-cookies] { background: var(--accent); color: #0A0F1A; font-weight: 600; }
#tab-mentions:checked ~ .legal-body #pane-mentions,
#tab-confid:checked ~ .legal-body #pane-confid,
#tab-cookies:checked ~ .legal-body #pane-cookies { display: grid; gap: 36px; }

.legal-body { display: grid; grid-template-columns: 220px 1fr; gap: 56px; align-items: start; margin-top: 20px; }
.toc { position: sticky; top: 24px; }
.toc h6 { font: 500 10.5px/1 var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin: 0 0 14px; }
.toc ol { list-style: none; display: grid; gap: 8px; font: 400 12.5px/1.4 var(--sans); }
.toc a { color: var(--ink-2); }

.legal-sect h2 { font: 500 22px/1.2 var(--sans); letter-spacing: -.015em; margin: 0; display: flex; align-items: baseline; gap: 18px; }
.legal-sect h2 .num { color: var(--accent); font-size: 26px; letter-spacing: -.025em; }
.legal-sect p { font: 400 14.5px/1.7 var(--sans); color: var(--ink-2); margin: 0; }
.legal-sect ul { list-style: none; display: grid; gap: 8px; }
.legal-sect ul li { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: baseline;
  font: 400 14px/1.55 var(--sans); color: var(--ink-2); }
.legal-sect ul li::before { content: "↳"; color: var(--accent); font-family: var(--mono); font-size: 11px; }
.legal-sect code { font-family: var(--mono); font-size: 13px; color: var(--accent); background: rgba(217,119,87,.08); padding: 1px 5px; border-radius: 3px; }

/* ─── Mobile menu (hamburger) — only visible <860px ─── */
.menu-btn {
  display: none;
  width: 36px; height: 36px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--rule-2);
  border-radius: var(--rad);
  cursor: pointer;
  align-items: center; justify-content: center;
}
.menu-btn svg { width: 16px; height: 12px; }
.menu-drawer { display: none; }

/* ─── Responsive — < 1080px collapses to single-col + hamburger ─── */
@media (max-width: 1080px) {
  .wrap { padding: 0 18px; }
  .statusbar, .hdr, .sect, .sect-sm, .sect-tight, .hero, .ftr { padding-left: 18px; padding-right: 18px; }
  .hero { padding-top: 44px; padding-bottom: 32px; }
  .sect, .sect-sm { padding-top: 36px; padding-bottom: 36px; }

  .hdr nav, .hdr .ctas { display: none; }
  .menu-btn { display: inline-flex; }
  .menu-drawer.is-open { display: grid; gap: 4px; padding: 8px 18px 18px; border-bottom: 1px solid var(--rule); }
  .menu-drawer.is-open a { padding: 12px 6px; border-bottom: 1px solid var(--rule); color: var(--ink); font: 500 14px/1 var(--sans); }
  .menu-drawer.is-open .btn-primary { margin-top: 12px; }

  .hero .cols { grid-template-columns: 1fr; gap: 32px; }
  .h1, .h1-xl, .sec-hero h1 { font-size: 38px; line-height: 1.02; }
  .h2 { font-size: 24px; }
  .h3 { font-size: 20px; }
  .lede { font-size: 15px; }

  .hero .ctas-row { display: grid; gap: 10px; }
  .hero .ctas-row .btn { width: 100%; justify-content: center; }

  .pillars { grid-template-columns: 1fr; }

  .review-card { padding: 28px 22px; }
  .review-card .cols { grid-template-columns: 1fr; gap: 36px; }

  .flow { grid-template-columns: 1fr; gap: 10px; }
  .flow-link { display: none; }
  .flow-node { min-height: auto; padding: 18px 20px; }

  .law { grid-template-columns: 1fr; }
  .law-col + .law-col { border-left: 0; border-top: 1px solid var(--rule); }

  .kv-strip { grid-template-columns: 1fr; }
  .kv-strip .kv + .kv { border-left: 0; border-top: 1px solid var(--rule); }

  .cta { grid-template-columns: 1fr; padding: 28px 22px; gap: 28px; }

  .form .grid-pair, .form .grid-pair.alt { grid-template-columns: 1fr; }
  .form .submit-row { flex-direction: column; align-items: stretch; gap: 12px; }
  .form .submit-row .btn { width: 100%; justify-content: center; }

  .sect-head { flex-direction: column; align-items: flex-start; gap: 14px; margin-bottom: 22px; }

  .tmg-list .row { flex-direction: column; align-items: flex-start; gap: 4px; }

  .ftr .row { flex-direction: column; align-items: flex-start; gap: 20px; }
  .ftr .links { flex-wrap: wrap; gap: 14px; }

  /* sectors */
  .sectors .row { grid-template-columns: auto 1fr; }
  .sectors .row .naf { grid-column: 1 / span 2; font-size: 10px; }

  /* security */
  .grid-2.col-pair { grid-template-columns: 1fr; }

  /* legal */
  .legal-body { grid-template-columns: 1fr; gap: 28px; }
  .toc { position: static; }
  .legal-tabs { display: flex; width: 100%; }
  .legal-tabs label { flex: 1; text-align: center; }
}

/* ─── Print: usable enough as PDF (legal page, security) ─── */
@media print {
  body { background: #fff; color: #000; }
  .hdr, .ftr, .statusbar, .menu-btn, .menu-drawer { display: none; }
  .wrap { max-width: 100%; padding: 0; }
  * { box-shadow: none !important; }
}
