/* ============================================================
 * Damaros — journey-doc.css  (v2: editorial pass)
 * The home journey's design language, laid over the doc pages
 * (runtime / fhir / about) as a quiet skin. Loads AFTER damaros.css.
 *
 * Vocabulary carried over from index:
 *   · the WebGL world (skydome + datum terrain) behind everything
 *   · jet geology with steel (#A9C0D6) hairlines
 *   · cold-white Archivo display, tight tracking; Hanken body
 *   · glass cards: 14px radius, inset steel ring, faint lift
 *   · numbered ledger sections, glowing pipeline for chains
 *   · status colors: ok #5BB98C · amber #D9A23E · breach #F2566E
 * ============================================================ */

/* ---- journey palette pinned (dark-only, like the home deck) ---- */
:root, [data-theme="dark"] {
  --jet:#06080b; --jet2:#0c1118;
  --cold:#E8ECF0; --steel:#A9C0D6; --deep:#2F5F8C;
  --amber:#D9A23E; --ok:#5BB98C; --breach:#F2566E; --dim:#7C8A99;

  --bg:var(--jet); --bg-1:#080b11; --bg-2:var(--jet2);
  --panel-solid:#0a0e14;
  --panel:linear-gradient(180deg, rgba(169,192,214,.07), rgba(169,192,214,.02)),
          linear-gradient(180deg, rgba(8,11,17,.55), rgba(8,11,17,.55));

  --fg:var(--cold);
  --fg-2:rgba(232,236,240,.72);
  --fg-3:rgba(232,236,240,.45);

  --accent:var(--steel); --accent-2:var(--steel); --accent-bright:var(--steel);

  --pass:var(--ok); --review:var(--amber); --fail:var(--breach); --luna:#8C7CF0;

  --bd:rgba(169,192,214,.22);
  --bd-soft:rgba(169,192,214,.12);
  --bd-strong:rgba(169,192,214,.4);
  --chip-bg:rgba(169,192,214,.05);

  --grid-line:rgba(169,192,214,.05);
  --scan:rgba(169,192,214,.018);
  --shadow-panel:0 18px 48px rgba(5,7,11,.4);
  --glow:0 0 42px rgba(169,192,214,.14);

  /* shared card recipe */
  --card-ring:inset 0 0 0 1px rgba(169,192,214,.22);
  --card-ring-hover:inset 0 0 0 1px rgba(169,192,214,.42), 0 14px 40px rgba(5,7,11,.5);
  --card-bg:linear-gradient(180deg, rgba(169,192,214,.07), rgba(169,192,214,.02)), rgba(8,11,17,.55);
  --hairline:rgba(169,192,214,.08);

  color-scheme:dark;
}
html { background:var(--jet); }
body { background:var(--jet); }

/* ============================================================
 * The world — fixed WebGL backdrop (shared/doc-world.js)
 * ============================================================ */
#world {
  position:fixed; inset:0; width:100vw; height:100vh; display:block; z-index:0;
  opacity:0; transition:opacity .55s ease;
}
body.world-ready #world { opacity:1; }
@media (max-width:820px) {
  #world { transition:opacity .72s ease; }
  body.doc-intro .docs,
  body.doc-intro .about { opacity:0; }
  body.world-ready .docs,
  body.world-ready .about { opacity:1; transition:opacity .45s ease .08s; }
}
/* legibility scrim — a whisper only: doc-world.js now ships the home page's own
   vignette, so the world reads at the same brightness as the home deck */
.world-scrim {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:linear-gradient(180deg, rgba(6,8,11,0) 0%, rgba(6,8,11,.10) 38%, rgba(6,8,11,.16) 100%);
}

/* ============================================================
 * Reading progress + station rail (built by shared/doc-ui.js)
 * ============================================================ */
.doc-progress {
  position:fixed; top:60px; left:0; right:0; height:2px; z-index:99; pointer-events:none;
}
.doc-progress span {
  display:block; height:100%; width:0;
  background:linear-gradient(90deg, rgba(169,192,214,.25), var(--steel));
  box-shadow:0 0 10px rgba(169,192,214,.45);
}
.doc-rail {
  position:fixed; right:clamp(.9rem,1.8vw,1.7rem); top:50%; transform:translateY(-50%);
  z-index:60; display:flex; flex-direction:column; gap:.18rem;
}
.doc-rail button {
  display:flex; align-items:center; justify-content:flex-end; gap:.5rem;
  background:none; border:0; cursor:pointer; padding:.22rem .1rem;
  font-family:var(--fh); font-weight:600; font-size:.6rem; letter-spacing:.06em;
  color:var(--dim); font-variant-numeric:tabular-nums;
  transition:color var(--t) var(--ease); -webkit-tap-highlight-color:transparent;
}
.doc-rail .rl-k {
  font-family:var(--fb); font-weight:600; font-size:.52rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--dim); opacity:0; transform:translateX(4px);
  transition:opacity var(--t) var(--ease), transform var(--t) var(--ease), color var(--t) var(--ease);
  white-space:nowrap;
}
.doc-rail .rl-t {
  width:14px; height:1px; background:rgba(169,192,214,.3); flex:none;
  transition:width var(--t) var(--ease), background var(--t) var(--ease), box-shadow var(--t) var(--ease);
}
.doc-rail button:hover { color:var(--cold); }
.doc-rail button:hover .rl-k { opacity:.9; transform:none; }
.doc-rail button[aria-current="true"] { color:var(--cold); }
.doc-rail button[aria-current="true"] .rl-t {
  width:26px; background:var(--steel); box-shadow:0 0 8px rgba(169,192,214,.55);
}
@media (max-width:1240px) { .doc-rail { display:none; } }

/* ============================================================
 * Scroll choreography — driven by rAF tweens in doc-ui.js
 * (no CSS-transition gates: content is never hidden by default)
 * ============================================================ */
@media (max-width:820px) {
  .doc-reveal-in {
    animation: docReveal .48s cubic-bezier(.16,1,.3,1) forwards;
  }
  @keyframes docReveal {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: none; }
  }
}
@media (prefers-reduced-motion: reduce) {
  .doc-reveal-in { animation: none; }
}

/* ============================================================
 * Page scaffold
 * ============================================================ */
.docs, .about {
  max-width:1120px; margin:0 auto;
  padding:calc(60px + clamp(3.4rem,9vh,5.5rem)) clamp(1.1rem,4vw,2.4rem) 7rem;
  position:relative; z-index:1;
}

/* eyebrow — steel signal dot + spaced kicker (echoes the deck's chips) */
.d-eyebrow, .a-eyebrow {
  display:flex; align-items:center; gap:.6rem;
  font-family:var(--fb); font-size:.64rem; font-weight:600;
  letter-spacing:.26em; text-transform:uppercase; color:var(--dim);
  margin-bottom:1.1rem;
}
.d-eyebrow::before, .a-eyebrow::before {
  content:""; width:5px; height:5px; border-radius:50%; flex:none;
  background:var(--steel); box-shadow:0 0 8px color-mix(in srgb, var(--steel) 55%, transparent);
}

/* hero title — display register, journey tracking (overrides damaros nowrap clamp) */
.d-title, .a-title {
  font-family:var(--fh); font-weight:750; color:var(--cold);
  font-size:clamp(2.5rem,5.6vw,3.9rem); letter-spacing:-.04em; line-height:.98;
  white-space:normal; text-wrap:balance; max-width:18ch;
}
.a-title { font-size:clamp(2rem,4.6vw,3.3rem); max-width:16ch; }

.d-lead {
  color:var(--fg-2); font-family:var(--fb);
  font-size:clamp(1rem,1.25vw,1.14rem); font-weight:400; line-height:1.62;
  margin:1.3rem 0 0; max-width:62ch; text-wrap:pretty;
}
.d-lead strong, .d-lead b { color:var(--cold); font-weight:600; }

.cross-link {
  display:inline-flex; align-items:center; gap:.45rem; margin-top:1.6rem;
  font-family:var(--fb); font-size:.64rem; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--steel); text-decoration:none;
  border-bottom:1px solid transparent; padding-bottom:2px;
  transition:color var(--t) var(--ease), border-color var(--t) var(--ease);
}
.cross-link:hover { color:var(--cold); border-color:var(--bd-strong); }

.divider {
  height:1px; margin:clamp(2.8rem,6vh,4rem) 0 clamp(1.4rem,3vh,2rem);
  background:linear-gradient(90deg, rgba(169,192,214,.3), rgba(169,192,214,.05));
}

/* ============================================================
 * Sections — numbered ledger: sticky Archivo index left, content right
 * ============================================================ */
section.doc {
  display:grid; grid-template-columns:168px minmax(0,1fr);
  column-gap:clamp(1.8rem,3.6vw,3.4rem);
  border-top:1px solid var(--bd-soft);
  padding-top:clamp(1.7rem,3.4vh,2.4rem);
  margin-bottom:clamp(2.8rem,5.5vh,4rem);
  scroll-margin-top:88px;
}
section.doc > * { grid-column:2; min-width:0; }
section.doc > .sec-label {
  grid-column:1; grid-row:1 / span 32; align-self:start;
  position:sticky; top:88px;
  display:flex; flex-direction:column; gap:.5rem; margin:0;
}
.sec-label .sl-n {
  font-family:var(--fh); font-weight:750; font-size:1.55rem; line-height:1;
  letter-spacing:-.02em; color:var(--steel); font-variant-numeric:tabular-nums;
}
.sec-label .sl-k {
  font-family:var(--fb); font-weight:600; font-size:.56rem; line-height:1.6;
  letter-spacing:.2em; text-transform:uppercase; color:var(--dim); max-width:12em;
}

.sec-head {
  font-family:var(--fh); font-weight:700; letter-spacing:-.025em;
  font-size:clamp(1.35rem,2vw,1.7rem); line-height:1.12; color:var(--cold);
  margin:0 0 1.15rem; padding:0; border:0; text-wrap:balance;
}

.body {
  color:var(--fg-2); font-family:var(--fb); font-size:clamp(.96rem,1.1vw,1.02rem);
  font-weight:400; line-height:1.66; max-width:70ch; text-wrap:pretty;
}
.body p { margin:0 0 .85rem; }
.body p:last-child { margin-bottom:0; }
.body strong { color:var(--cold); font-weight:600; }
.body a, .kv a { color:var(--steel); }
.body a:hover, .kv a:hover { color:var(--cold); }
.body code, .kv code, .scopes code, .flow code {
  font-family:var(--fm); color:var(--steel); font-size:.9em; font-weight:500;
}

/* ---- key/value tables — hairline ledger ---- */
.kv { width:100%; border-collapse:collapse; font-family:var(--fb); font-size:.86rem; margin-top:.7rem; }
.kv tr { border-bottom:1px solid var(--hairline); }
.kv tr:last-child { border-bottom:0; }
.kv td { padding:.7rem 0; vertical-align:top; line-height:1.56; }
.kv td:first-child {
  width:232px; padding-right:1.5rem;
  font-weight:600; font-size:.76rem; letter-spacing:.05em; color:var(--steel);
}
.kv td:last-child { color:var(--fg-2); }

/* ---- bullets — open hairline rows (deck's gap-list), no glyphs ---- */
.bullets { list-style:none; padding:0; margin:0; color:var(--fg-2); font-family:var(--fb); font-size:.92rem; line-height:1.52; }
.bullets li { padding:.62rem 0; border-top:1px solid var(--hairline); text-wrap:pretty; }
.bullets li:first-child { border-top:0; padding-top:.1rem; }
.bullets strong { color:var(--cold); font-weight:600; }
.bullets a { color:var(--steel); }
.bullets a:hover { color:var(--cold); }

/* ---- callout — quiet ringed band, steel emphasis variant ---- */
.callout {
  margin:1.25rem 0 0; padding:.95rem 1.2rem;
  border:1px solid rgba(169,192,214,.16); border-radius:12px;
  background:rgba(169,192,214,.04);
  color:var(--fg-2); font-family:var(--fb); font-size:.85rem; line-height:1.6; text-wrap:pretty;
}
.callout strong { color:var(--cold); font-weight:600; }
.callout.em { border-color:rgba(169,192,214,.3); background:linear-gradient(180deg, rgba(169,192,214,.07), rgba(169,192,214,.02)); }

/* ============================================================
 * Cards — one recipe, shared with the deck
 * ============================================================ */
.dual { display:grid; grid-template-columns:1fr 1fr; gap:clamp(.95rem,1.6vw,1.35rem); margin-top:.2rem; }
.split-cards { display:grid; grid-template-columns:1fr 1fr; gap:clamp(.95rem,1.6vw,1.35rem); margin-top:.2rem; }
.deploy-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(.95rem,1.6vw,1.35rem); margin-top:.2rem; }

.dual-card, .scard, .foil {
  border:0; border-radius:14px;
  box-shadow:var(--card-ring);
  background:var(--card-bg);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  padding:clamp(1.15rem,1.9vh,1.45rem) clamp(1.2rem,1.7vw,1.45rem);
  transition:box-shadow .2s var(--ease), transform .2s var(--ease);
}
@media (hover:hover) and (pointer:fine) {
  .dual-card:hover, .scard:hover { box-shadow:var(--card-ring-hover); transform:translateY(-2px); }
}

/* allow / deny — colored signal dot instead of colored top border */
.dual-card h3 {
  display:flex; align-items:center; gap:.5rem; margin:0 0 .65rem;
  font-family:var(--fb); font-size:.6rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:rgba(232,236,240,.66);
}
.dual-card h3::before {
  content:""; width:6px; height:6px; border-radius:50%; flex:none;
  background:var(--c,var(--steel));
  box-shadow:0 0 8px color-mix(in srgb, var(--c,var(--steel)) 55%, transparent);
}
.dual-card.allow { --c:var(--ok); }
.dual-card.deny { --c:var(--breach); }
.dual-card .bullets { font-size:.87rem; }

/* scard — the deck's agent-card register */
.scard .sc-tag {
  display:block; margin-bottom:.6rem;
  font-family:var(--fb); font-size:.58rem; font-weight:600;
  letter-spacing:.2em; text-transform:uppercase; color:var(--steel);
}
.scard h3 {
  margin:0 0 .55rem; font-family:var(--fh); font-weight:700;
  font-size:clamp(1.08rem,1.4vw,1.28rem); letter-spacing:-.015em; color:var(--cold); line-height:1.15;
}
.scard p { margin:0; color:rgba(232,236,240,.62); font-family:var(--fb); font-size:.87rem; line-height:1.56; text-wrap:pretty; }

/* foil — flagship register (the deck's cold-lifted Replay card) */
.foil {
  box-shadow:inset 0 0 0 1px rgba(232,236,240,.3), inset 0 1px 0 rgba(232,236,240,.14), 0 0 30px rgba(169,192,214,.06);
  background:linear-gradient(180deg, rgba(232,236,240,.085), rgba(169,192,214,.02)), rgba(8,11,17,.6);
}
.foil p { margin:0; color:var(--fg-2); font-family:var(--fb); font-size:clamp(.95rem,1.15vw,1.04rem); line-height:1.68; text-wrap:pretty; }
.foil em { font-style:normal; color:var(--steel); font-weight:600; }

/* ============================================================
 * Chain — the deck's glowing pipeline, open, no boxes
 * ============================================================ */
.chain-mini {
  position:relative; display:grid; grid-template-columns:repeat(5,1fr);
  gap:clamp(1rem,1.9vw,1.7rem); border:0; background:none; border-radius:0; overflow:visible;
  margin-top:1.7rem; padding-top:1.5rem;
}
.chain-mini::before {
  content:""; position:absolute; top:4px; left:5px; right:5px; height:1px;
  background:linear-gradient(90deg, transparent, rgba(169,192,214,.42) 9%, rgba(169,192,214,.42) 91%, transparent);
}
.chain-step { position:relative; background:none; padding:0; }
.chain-step::before {
  content:""; position:absolute; top:-1.5rem; left:0; width:9px; height:9px; border-radius:50%;
  background:var(--steel); box-shadow:0 0 12px color-mix(in srgb, var(--steel) 55%, transparent);
}
.chain-step:last-child::before { background:var(--cold); box-shadow:0 0 13px rgba(232,236,240,.5); }
.chain-step .cs-n {
  font-family:var(--fh); font-weight:700; font-size:.74rem; letter-spacing:.04em;
  color:var(--steel); opacity:.6; text-transform:none; font-variant-numeric:tabular-nums;
}
.chain-step .cs-t {
  display:block; margin-top:.32rem;
  font-family:var(--fh); font-weight:700; font-size:1.02rem;
  letter-spacing:-.015em; color:var(--cold); line-height:1.2;
}
.chain-step .cs-d { margin:.5rem 0 0; font-family:var(--fb); font-size:.77rem; line-height:1.52; color:rgba(232,236,240,.56); text-wrap:pretty; }
.chain-step .cs-d strong { color:var(--steel); font-weight:600; }

/* ============================================================
 * FHIR page extras
 * ============================================================ */
/* flow — pill chips joined by steel arrows (deck's es-chip register) */
.flow { display:flex; flex-wrap:wrap; align-items:center; gap:.5rem; margin:1.1rem 0 0; }
.flow .f-step {
  display:inline-flex; align-items:center;
  font-family:var(--fb); font-size:.64rem; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; color:rgba(232,236,240,.74);
  padding:.42rem .85rem; border:1px solid var(--bd); border-radius:999px;
  background:rgba(169,192,214,.04); white-space:nowrap;
}
.flow .f-arrow { color:var(--steel); font-size:.72rem; opacity:.65; }

/* scopes — hairline ledger */
.scopes { list-style:none; padding:0; margin:0; }
.scopes li {
  display:grid; grid-template-columns:280px 1fr; gap:1rem; align-items:baseline;
  padding:.6rem 0; border-bottom:1px solid var(--hairline); font-size:.86rem;
}
.scopes li:last-child { border-bottom:0; }
.scopes .sn { font-family:var(--fb); font-weight:600; font-size:.79rem; letter-spacing:.02em; color:var(--steel); }
.scopes .sd { color:var(--fg-2); line-height:1.52; }

/* code blocks */
pre.code {
  margin:1rem 0 0; padding:1.05rem 1.2rem;
  border:0; border-radius:12px;
  box-shadow:inset 0 0 0 1px rgba(169,192,214,.16);
  background:rgba(8,11,17,.66);
  font-family:var(--fm); font-size:.75rem; line-height:1.62; color:var(--fg-2);
  overflow-x:auto;
}
.pre-cap {
  font-family:var(--fb); font-size:.58rem; font-weight:600; letter-spacing:.18em;
  text-transform:uppercase; color:var(--dim); margin:1.4rem 0 .35rem;
}
.pre-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }

.contact { font-family:var(--fb); font-size:.9rem; line-height:2.15; color:var(--fg-2); }
.contact a { color:var(--steel); }
.contact a:hover { color:var(--cold); }

/* ============================================================
 * About page — the letter fills the measure; founder card rides beside it
 * ============================================================ */
.a-title { font-size:clamp(2rem,5.2vw,3.6rem); max-width:none; }

.a-grid {
  display:grid; grid-template-columns:minmax(0,1fr) 300px;
  gap:clamp(2rem,5vw,4.5rem); align-items:start;
  margin-top:clamp(1.9rem,4.5vh,2.8rem);
  padding-top:clamp(1.6rem,3.5vh,2.2rem);
  border-top:1px solid var(--bd-soft);
}
.a-side { position:sticky; top:88px; }
.a-card {
  display:flex; flex-direction:column; gap:.4rem;
  border-radius:14px; box-shadow:var(--card-ring); background:var(--card-bg);
  -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px);
  padding:1.3rem 1.35rem;
}
.a-name { font-family:var(--fh); font-weight:700; font-size:1.12rem; letter-spacing:-.015em; color:var(--cold); line-height:1.25; }
.a-role {
  font-family:var(--fb); font-size:.58rem; font-weight:600;
  letter-spacing:.18em; text-transform:uppercase; color:var(--steel); opacity:.85; line-height:1.6;
}
.a-card .dmx-cta { margin-top:1.05rem; justify-content:center; }
.a-linkedin svg { width:16px; height:16px; display:block; flex-shrink:0; }

.a-prose {
  color:var(--fg-2); font-family:var(--fb);
  font-size:clamp(1.02rem,1.3vw,1.14rem);
  font-weight:400; line-height:1.7; text-wrap:pretty; max-width:70ch;
}
.a-prose p { margin:0 0 1.05rem; }
.a-prose p:last-child { margin-bottom:0; }
.a-prose .a-lead { color:var(--cold); font-size:clamp(1.12rem,1.55vw,1.32rem); line-height:1.55; }
.a-prose strong { color:var(--cold); font-weight:600; }

/* pull quote — deck headline register: cold Archivo, steel tail */
.a-pull {
  margin:clamp(1.8rem,4.5vh,2.5rem) 0 !important; padding:0; border:0;
  font-family:var(--fh); font-weight:750;
  font-size:clamp(1.5rem,3vw,2.1rem); line-height:1.12; letter-spacing:-.03em;
  color:var(--cold) !important; text-wrap:balance;
}
.a-pull em { font-style:normal; color:var(--steel); }

.a-doctrine {
  margin-top:clamp(1.8rem,4.5vh,2.6rem) !important;
  padding-top:clamp(1.5rem,3.6vh,2.1rem);
  border-top:1px solid var(--bd-soft);
  color:var(--steel) !important;
  font-family:var(--fh); font-weight:600;
  font-size:clamp(1.08rem,1.6vw,1.3rem); line-height:1.34; letter-spacing:-.012em; text-wrap:balance;
}
.a-doctrine em { font-style:normal; color:var(--cold); }

/* ============================================================
 * Footer
 * ============================================================ */
footer {
  border-top:1px solid var(--bd-soft);
  padding:2.2rem clamp(1.1rem,4vw,2.4rem);
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center;
  font-family:var(--fb); font-weight:600; font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--dim);
  max-width:1120px; margin:0 auto; position:relative; z-index:1;
}
footer .geo { justify-self:start; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
footer .geo.pending { opacity:.45; }
footer .cp { justify-self:center; }
footer a { justify-self:end; color:var(--dim); text-decoration:none; transition:color var(--t) var(--ease); }
footer a:hover { color:var(--cold); }

/* ============================================================
 * Responsive
 * ============================================================ */
@media (max-width:1000px) {
  .a-grid { grid-template-columns:1fr; gap:1.6rem; }
  .a-side { position:static; grid-row:1; }
  .a-card { flex-direction:row; align-items:center; flex-wrap:wrap; gap:.3rem 1rem; padding:1.05rem 1.2rem; }
  .a-name { width:100%; }
  .a-card .dmx-cta { margin:0.55rem 0 0; width:100%; }
}
@media (max-width:900px) {
  section.doc { display:block; }
  section.doc > .sec-label {
    position:static; flex-direction:row; align-items:baseline; gap:.65rem; margin-bottom:.8rem;
  }
  .sec-label .sl-n { font-size:1.05rem; }
  .chain-mini { grid-template-columns:repeat(2,1fr); padding-top:0; }
  .chain-mini::before { display:none; }
  .chain-step::before { position:static; display:block; margin-bottom:.5rem; }
  .deploy-grid { grid-template-columns:1fr; }
}
@media (max-width:820px) {
  .docs, .about { padding-top:calc(60px + 2.7rem); padding-bottom:4.5rem; }
  .d-title { font-size:clamp(2.05rem,8.6vw,2.7rem); }
  .a-title { font-size:clamp(1.75rem,7.6vw,2.4rem); }
  .d-lead { font-size:1rem; }
  .sec-head { font-size:1.32rem; margin-bottom:.95rem; }
  .body { font-size:1rem; }
  .a-prose { font-size:1.02rem; }
  .dual, .split-cards, .pre-grid { grid-template-columns:1fr; }
  .divider { margin:2.2rem 0 1.2rem; }
  section.doc { margin-bottom:2.4rem; padding-top:1.5rem; }
  footer {
    grid-template-columns:1fr; gap:.6rem; justify-items:center; text-align:center;
    padding:1.9rem 1.1rem;
  }
  footer .geo, footer .cp, footer a { justify-self:center; }
}
@media (max-width:620px) {
  /* kv ledger stacks: label above value, full width — no cramped columns */
  .kv, .kv tbody, .kv tr, .kv td { display:block; width:100%; }
  .kv { margin-top:.4rem; }
  .kv tr { padding:.6rem 0; border-bottom:1px solid var(--hairline); }
  .kv tr:last-child { border-bottom:0; }
  .kv td { padding:0; line-height:1.55; }
  .kv td:first-child {
    width:auto; padding:0 0 .22rem; white-space:normal;
    font-size:.64rem; letter-spacing:.14em; text-transform:uppercase;
  }
  .scopes li { grid-template-columns:1fr; gap:.14rem; padding:.62rem 0; }
  .flow .f-step { font-size:.6rem; padding:.38rem .7rem; }
  pre.code { font-size:.72rem; padding:.9rem .95rem; }
}
@media (max-width:480px) {
  .chain-mini { grid-template-columns:1fr; gap:1.15rem; }
  .chain-step .cs-d { font-size:.8rem; }
}
