/* =====================================================================
   VRANGR — Secure operational intelligence
   Brand system v5 "Blackfile". Dark, severe, institutional.
   1980s/1990s U.S. government clandestine-operations atmosphere built
   from documents, terminals, redaction bars, routing lines, and stamps.
   The existing corner-bracket logo is preserved, not redesigned; its
   crop-mark geometry drives frames, panels, and the wordmark lockup.
   Dependency-free. One stylesheet drives every page.
   ===================================================================== */

/* ---------------------------------------------------------------------
   Tokens — blackfile palette
   --------------------------------------------------------------------- */
:root {
  --black: #050505;
  --blackfile: #0b0b09;
  --graphite: #171715;
  --olive-deep: #1e241b;
  --faded-olive: #6f755b;
  --green: #7c8b66;     /* classified green — active / route approved */
  --amber: #b08a47;     /* dim amber — controls, route lines, eyebrows */
  --red: #9e2f28;       /* red stamp — restricted / blocked only */
  --off: #e8e1cf;       /* off-white — dominant ink */
  --paper: #cfc4a7;     /* aged paper — document surfaces */
  --paper-ink: #211d14; /* ink on aged paper */
  --photocopy: #8d897b; /* muted gray text */

  /* semantic — dark blackfile is the default surface */
  --bg: var(--black);
  --panel: var(--blackfile);
  --panel-2: var(--graphite);
  --fg: var(--off);
  --fg-mute: var(--photocopy);
  --line: rgba(232, 225, 207, 0.15);
  --line-soft: rgba(232, 225, 207, 0.08);
  --accent: var(--amber);

  --maxw: 1200px;
  --gut: clamp(20px, 5vw, 64px);
  --bracket: 15px;

  --mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;
  --sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --ease: cubic-bezier(0.2, 0.7, 0.2, 1);
}

/* Aged-paper surface context — for dossier / blackfile documents */
.on-paper {
  --bg: var(--paper);
  --panel: #d8cdb0;
  --panel-2: #c6b99a;
  --fg: var(--paper-ink);
  --fg-mute: #5a5340;
  --line: rgba(33, 29, 20, 0.22);
  --line-soft: rgba(33, 29, 20, 0.12);
  color: var(--fg);
  background: var(--bg);
}

/* ---------------------------------------------------------------------
   Reset / base
   --------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation: none !important; transition: none !important; }
}

body {
  font-family: var(--sans);
  background: var(--black);
  color: var(--off);
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
}

/* Faint global scanline / archive texture — kept very low contrast */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background-image: repeating-linear-gradient(
    0deg, rgba(232, 225, 207, 0.025) 0, rgba(232, 225, 207, 0.025) 1px, transparent 1px, transparent 3px);
  opacity: 0.5;
}
body > * { position: relative; z-index: 2; }
@media (prefers-reduced-motion: reduce) { body::before { display: none; } }

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
input, select, textarea { font: inherit; }

::selection { background: var(--off); color: var(--black); }
.on-paper ::selection { background: var(--paper-ink); color: var(--paper); }

:focus-visible { outline: 2px solid var(--amber); outline-offset: 3px; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

.skip {
  position: absolute; left: 12px; top: -56px; z-index: 200;
  background: var(--off); color: var(--black);
  padding: 10px 16px; font: 600 13px/1 var(--mono); letter-spacing: 0.04em;
  transition: top 0.2s var(--ease);
}
.skip:focus { top: 12px; }

/* ---------------------------------------------------------------------
   Layout primitives
   --------------------------------------------------------------------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gut); }
.section { padding-block: clamp(60px, 10vw, 124px); position: relative; }
.section--tight { padding-block: clamp(44px, 7vw, 84px); }
.surface-paper { background: var(--paper); color: var(--paper-ink); }
.surface-graphite { background: var(--graphite); }
.rule { height: 1px; background: var(--line); border: 0; }

/* ---------------------------------------------------------------------
   Type scale
   --------------------------------------------------------------------- */
.display { font-weight: 600; font-size: clamp(2.4rem, 6.2vw, 4.9rem); line-height: 0.99; letter-spacing: -0.025em; }
.h2 { font-weight: 600; font-size: clamp(1.65rem, 3.5vw, 2.7rem); line-height: 1.05; letter-spacing: -0.02em; }
.h3 { font-weight: 600; font-size: clamp(1.1rem, 1.6vw, 1.3rem); line-height: 1.18; letter-spacing: -0.01em; }
.lede { font-size: clamp(1.05rem, 1.7vw, 1.28rem); line-height: 1.5; color: var(--fg-mute); max-width: 60ch; }
.prose { color: var(--fg-mute); max-width: 64ch; }
.prose + .prose { margin-top: 1em; }

/* SectionLabel — monospaced, uppercase, with a bracket tick */
.label {
  display: inline-flex; align-items: center; gap: 0.6em;
  font: 500 0.72rem/1 var(--mono);
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--fg-mute);
}
.label::before {
  content: ""; width: 9px; height: 9px;
  border-left: 1.5px solid var(--accent); border-top: 1.5px solid var(--accent);
}
.label--accent { color: var(--amber); }
.label--green { color: var(--green); }
.label--green::before { border-color: var(--green); }
.label--red { color: var(--red); }
.label--red::before { border-color: var(--red); }

/* Classification stamp — fictional / generic labels only */
.stamp {
  display: inline-flex; align-items: center; gap: 0.5em;
  font: 600 0.62rem/1 var(--mono); letter-spacing: 0.18em; text-transform: uppercase;
  padding: 5px 9px; border: 1.5px solid currentColor; color: var(--fg-mute);
}
.stamp--amber { color: var(--amber); }
.stamp--green { color: var(--green); }
.stamp--red { color: var(--red); }

/* ---------------------------------------------------------------------
   BracketFrame — opposing TL + BR corner crop marks (logo-derived motif)
   --------------------------------------------------------------------- */
.frame { position: relative; padding: clamp(20px, 3vw, 34px); }
.frame::before, .frame::after {
  content: ""; position: absolute; width: var(--bracket); height: var(--bracket);
  border-color: var(--fg); border-style: solid; border-width: 0;
}
.frame::before { top: 0; left: 0; border-top-width: 1.5px; border-left-width: 1.5px; }
.frame::after  { bottom: 0; right: 0; border-bottom-width: 1.5px; border-right-width: 1.5px; }
.frame--accent::before, .frame--accent::after { border-color: var(--amber); }
.frame--full { border: 1px solid var(--line); }

/* ---------------------------------------------------------------------
   Bracket mark (standalone logo symbol) + wordmark lockup — PRESERVED
   --------------------------------------------------------------------- */
.mark { color: var(--fg); display: block; }
.mark svg { width: 100%; height: 100%; }

.lockup { position: relative; display: inline-flex; align-items: center; padding: 0.42em 0.62em; line-height: 1; }
.lockup::before, .lockup::after {
  content: ""; position: absolute; width: 0.5em; height: 0.5em;
  border-color: currentColor; border-style: solid; border-width: 0;
}
.lockup::before { top: 0; left: 0; border-top-width: 2px; border-left-width: 2px; }
.lockup::after  { bottom: 0; right: 0; border-bottom-width: 2px; border-right-width: 2px; }
.lockup__word { font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; font-size: 1rem; }

.stack { display: inline-flex; flex-direction: column; align-items: center; gap: 16px; }
.stack .mark { width: 52px; height: 52px; }
.stack .lockup__word { font-size: 1.3rem; letter-spacing: 0.28em; }

/* ---------------------------------------------------------------------
   Navigation
   --------------------------------------------------------------------- */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: color-mix(in srgb, var(--black) 88%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line-soft);
}
.nav__inner { display: flex; align-items: center; gap: 22px; height: 64px; }
.brand { display: inline-flex; align-items: center; gap: 11px; color: var(--off); }
.brand .mark { width: 26px; height: 26px; }
.brand .lockup__word { font-size: 0.95rem; }
.nav__spacer { flex: 1; }
.nav__links { display: flex; align-items: center; gap: 24px; }
.nav__links a {
  font: 500 0.82rem/1 var(--sans); letter-spacing: 0.01em; color: var(--fg-mute);
  position: relative; padding-block: 6px; transition: color 0.18s var(--ease);
}
.nav__links a:hover, .nav__links a[aria-current="page"] { color: var(--off); }
.nav__links a[aria-current="page"]::after {
  content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; height: 1.5px; background: var(--amber);
}

.btn {
  display: inline-flex; align-items: center; gap: 0.6em;
  font: 600 0.83rem/1 var(--sans); letter-spacing: 0.01em;
  padding: 0.74em 1.15em; border: 1px solid transparent;
  transition: background 0.18s var(--ease), color 0.18s var(--ease), border-color 0.18s var(--ease);
  white-space: nowrap;
}
.btn--solid { background: var(--off); color: var(--black); }
.btn--solid:hover { background: #fff; }
.on-paper .btn--solid { background: var(--paper-ink); color: var(--paper); }
.on-paper .btn--solid:hover { background: var(--black); }
.btn--line { border-color: var(--line); color: var(--fg); }
.btn--line:hover { border-color: var(--fg); }
.btn--lg { padding: 0.95em 1.5em; font-size: 0.92rem; }
.btn .arr { transition: transform 0.2s var(--ease); }
.btn:hover .arr { transform: translateX(3px); }

.nav__toggle { display: none; width: 40px; height: 40px; margin-left: auto; position: relative; }
.nav__toggle span { position: absolute; left: 9px; width: 22px; height: 1.5px; background: var(--off); transition: transform 0.2s var(--ease), opacity 0.2s var(--ease); }
.nav__toggle span:nth-child(1) { top: 14px; }
.nav__toggle span:nth-child(2) { top: 20px; }
.nav__toggle span:nth-child(3) { top: 26px; }
.nav.is-open .nav__toggle span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav.is-open .nav__toggle span:nth-child(2) { opacity: 0; }
.nav.is-open .nav__toggle span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 920px) {
  .nav__links, .nav__cta { display: none; }
  .nav__toggle { display: block; }
  .nav.is-open .nav__links {
    display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
    position: absolute; left: 0; right: 0; top: 64px;
    background: var(--blackfile); border-bottom: 1px solid var(--line);
    padding: 14px var(--gut) 22px;
  }
  .nav.is-open .nav__links a { font-size: 1.05rem; padding-block: 10px; }
}

/* ---------------------------------------------------------------------
   DocBar — classified-style document header strip (case no / time / access)
   --------------------------------------------------------------------- */
.docbar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 18px;
  font: 500 0.66rem/1 var(--mono); letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--fg-mute); padding: 11px 16px;
  border: 1px solid var(--line); background: var(--panel);
}
.docbar__k { color: var(--fg-mute); }
.docbar__v { color: var(--fg); }
.docbar__sep { flex: 1; min-width: 12px; }
.docbar__dot { width: 6px; height: 6px; border-radius: 50%; background: var(--green); display: inline-block; }

/* ---------------------------------------------------------------------
   Hero
   --------------------------------------------------------------------- */
.hero { padding-block: clamp(40px, 7vw, 80px) clamp(56px, 9vw, 104px); overflow: hidden; }
.hero__doc { margin-bottom: clamp(28px, 4vw, 44px); }
.hero__grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.hero__copy, .hero__visual { min-width: 0; }
.hero__eyebrow { margin-bottom: 24px; }
.hero h1 { margin-bottom: 22px; }
.hero .lede { margin-bottom: 32px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 38px; }
.hero__meta { display: flex; flex-wrap: wrap; gap: 16px 28px; padding-top: 22px; border-top: 1px solid var(--line); }
.hero__meta div { padding-right: 28px; }
.hero__meta dt { font: 500 0.64rem/1 var(--mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 7px; }
.hero__meta dd { font-weight: 500; font-size: 0.92rem; }

@media (max-width: 900px) {
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
}

/* ---------------------------------------------------------------------
   Terminal panel — the secure-terminal flow (hero + demo)
   --------------------------------------------------------------------- */
.term { border: 1px solid var(--line); background: var(--panel); }
.term__bar {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border-bottom: 1px solid var(--line); background: var(--panel-2);
  font: 500 0.64rem/1 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-mute);
}
.term__dot { width: 7px; height: 7px; border-radius: 50%; background: var(--faded-olive); }
.term__dot.is-live { background: var(--green); }
.term__title { margin-left: 2px; }
.term__tag { margin-left: auto; color: var(--amber); }

.loop { display: grid; }
.loop__row {
  position: relative; display: grid; grid-template-columns: 34px 92px 1fr auto; align-items: center;
  gap: 14px; padding: 13px 16px; border-bottom: 1px solid var(--line-soft);
  transition: background 0.25s var(--ease);
}
.loop__row:last-child { border-bottom: 0; }
.loop__idx { font: 500 0.62rem/1 var(--mono); color: var(--fg-mute); }
.loop__step { font: 600 0.74rem/1 var(--mono); letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg); }
.loop__desc { font-size: 0.86rem; color: var(--fg-mute); }
.loop__tick { font: 500 0.62rem/1 var(--mono); letter-spacing: 0.1em; text-transform: uppercase; color: var(--faded-olive); white-space: nowrap; }
.loop__row.is-active { background: color-mix(in srgb, var(--green) 12%, transparent); }
.loop__row.is-active .loop__step { color: var(--green); }
.loop__row.is-active .loop__tick { color: var(--green); }
.loop__row.is-active::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--green);
}
@media (max-width: 520px) {
  .loop__row { grid-template-columns: 26px 1fr; row-gap: 4px; }
  .loop__desc { grid-column: 2; }
  .loop__tick { grid-column: 2; }
}

.term__foot {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 16px;
  padding: 12px 16px; border-top: 1px solid var(--line);
  font: 500 0.64rem/1 var(--mono); letter-spacing: 0.08em; color: var(--fg-mute);
}
.term__foot .btn { margin-left: auto; }

/* ---------------------------------------------------------------------
   Section header block
   --------------------------------------------------------------------- */
.head { max-width: 72ch; margin-bottom: clamp(32px, 5vw, 54px); }
.head .label { margin-bottom: 18px; }
.head h2 { margin-bottom: 18px; }
.head--split { display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; align-items: end; max-width: none; }
@media (max-width: 760px) { .head--split { grid-template-columns: 1fr; } }

/* ---------------------------------------------------------------------
   DossierPanel — blackfile document with access labels + redaction bars
   --------------------------------------------------------------------- */
.dossier { border: 1px solid var(--line); background: var(--panel); }
.dossier__head {
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px 16px;
  padding: 12px 18px; border-bottom: 1px solid var(--line); background: var(--panel-2);
}
.dossier__ref { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-mute); }
.dossier__body { padding: clamp(22px, 3vw, 34px); }
.dossier__q { display: grid; gap: 0; }
.dossier__q li {
  list-style: none; display: grid; grid-template-columns: 34px 1fr; gap: 14px; align-items: baseline;
  padding: 14px 0; border-bottom: 1px solid var(--line-soft); font-size: 1rem; color: var(--fg);
}
.dossier__q li:last-child { border-bottom: 0; }
.dossier__q .qn { font: 500 0.66rem/1 var(--mono); color: var(--amber); }

/* Redaction bar */
.redact { display: inline-block; height: 0.9em; background: currentColor; vertical-align: -0.12em; opacity: 0.92; }

/* ---------------------------------------------------------------------
   Card grids (blackfile panels, not SaaS cards)
   --------------------------------------------------------------------- */
.grid { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 820px) { .grid--3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .grid--3, .grid--2 { grid-template-columns: 1fr; } }

.cell { background: var(--panel); padding: clamp(20px, 2.6vw, 30px); display: flex; flex-direction: column; gap: 9px; min-height: 100%; }
.cell__n { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.14em; color: var(--fg-mute); }
.cell h3 { font-weight: 600; font-size: 1.04rem; letter-spacing: -0.01em; }
.cell p { font-size: 0.9rem; color: var(--fg-mute); }
.cell--mark { box-shadow: inset 0 2px 0 var(--amber); }

/* Capability panels — case-label feel */
.caps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (max-width: 820px) { .caps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .caps { grid-template-columns: 1fr; } }
.cap { background: var(--panel); padding: clamp(20px, 2.6vw, 28px); display: flex; flex-direction: column; gap: 10px; }
.cap__k { font: 500 0.62rem/1 var(--mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--amber); }
.cap h3 { font-weight: 600; font-size: 1.05rem; letter-spacing: -0.01em; }
.cap p { font-size: 0.88rem; color: var(--fg-mute); }

/* Risk / question chips — redaction-bar flavor */
.risks { display: flex; flex-wrap: wrap; gap: 10px; }
.risk { display: inline-flex; align-items: center; gap: 10px; font: 500 0.86rem/1.2 var(--sans); border: 1px solid var(--line); padding: 12px 15px; background: var(--panel); }
.risk::before { content: ""; width: 22px; height: 9px; background: var(--off); flex: none; opacity: 0.85; }
.on-paper .risk::before { background: var(--paper-ink); }

/* Principles / steps list */
.tenets { list-style: none; display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.tenet { background: var(--panel); display: grid; grid-template-columns: 56px 1fr; gap: 18px; padding: 22px clamp(20px, 2.6vw, 30px); align-items: baseline; }
.tenet__n { font: 500 0.9rem/1 var(--mono); color: var(--amber); letter-spacing: 0.08em; }
.tenet h3 { font-weight: 600; font-size: 1.05rem; }
.tenet p { font-size: 0.9rem; color: var(--fg-mute); margin-top: 5px; }

/* UseCaseCard */
.usecases { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (max-width: 720px) { .usecases { grid-template-columns: 1fr; } }
.usecase { background: var(--panel); padding: clamp(24px, 3vw, 36px); display: flex; flex-direction: column; gap: 11px; }
.usecase__k { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--amber); }
.usecase h3 { font-size: 1.22rem; font-weight: 600; letter-spacing: -0.015em; }
.usecase p { font-size: 0.92rem; color: var(--fg-mute); }

/* FieldNoteCard — research, declassified-memo styling */
.notes { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.note { background: var(--panel); display: grid; grid-template-columns: 96px 1fr auto; gap: 20px; padding: 20px clamp(18px, 2.4vw, 28px); align-items: baseline; transition: background 0.18s var(--ease); }
.note:hover { background: var(--panel-2); }
.note__ref { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.1em; color: var(--amber); }
.note h3 { font-size: 1.04rem; font-weight: 600; letter-spacing: -0.01em; }
.note__arr { color: var(--fg-mute); font-size: 0.85rem; }
@media (max-width: 600px) { .note { grid-template-columns: 1fr auto; } .note__ref { grid-column: 1 / -1; } }

/* ---------------------------------------------------------------------
   Decision / Route / Audit panels (demo)
   --------------------------------------------------------------------- */
.records { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.records--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 820px) { .records, .records--3 { grid-template-columns: 1fr; } }

.rec { border: 1px solid var(--line); background: var(--panel); display: flex; flex-direction: column; }
.rec__head { display: flex; align-items: center; gap: 10px; padding: 12px 16px; border-bottom: 1px solid var(--line); background: var(--panel-2);
  font: 600 0.66rem/1 var(--mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-mute); }
.rec__body { padding: 18px 16px; display: grid; gap: 10px; }
.rec__line { display: grid; grid-template-columns: 1fr auto; gap: 12px; align-items: baseline; font-size: 0.88rem; padding-bottom: 9px; border-bottom: 1px solid var(--line-soft); }
.rec__line:last-child { border-bottom: 0; padding-bottom: 0; }
.rec__k { color: var(--fg-mute); font: 500 0.72rem/1.3 var(--mono); letter-spacing: 0.04em; }
.rec__v { font-weight: 500; font-size: 0.85rem; text-align: right; }
.rec__v--ok { color: var(--green); }
.rec__v--block { color: var(--red); }
.rec__v--hold { color: var(--amber); }

/* status verdict header tints */
.rec--ok .rec__head { color: var(--green); }
.rec--block .rec__head { color: var(--red); }
.rec--hold .rec__head { color: var(--amber); }

/* ---------------------------------------------------------------------
   ModuleGrid / DeploymentGrid (operations map)
   --------------------------------------------------------------------- */
.modules { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (max-width: 720px) { .modules { grid-template-columns: 1fr; } }
.module { background: var(--panel); padding: clamp(22px, 3vw, 32px); display: grid; grid-template-columns: 40px 1fr; gap: 16px; align-items: start; }
.module__no { font: 500 0.8rem/1 var(--mono); color: var(--amber); padding-top: 3px; }
.module h3 { font-size: 1.12rem; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 6px; }
.module p { font-size: 0.9rem; color: var(--fg-mute); }

.deploy { display: grid; gap: 0; border: 1px solid var(--line); }
.deploy__row { display: grid; grid-template-columns: 64px 1fr auto; align-items: center; gap: 16px; padding: 18px clamp(16px, 2.4vw, 26px); border-bottom: 1px solid var(--line); background: var(--panel); }
.deploy__row:last-child { border-bottom: 0; }
.deploy__no { font: 500 0.74rem/1 var(--mono); color: var(--fg-mute); }
.deploy__name { font-weight: 600; font-size: 1.02rem; }
.deploy__note { font-size: 0.84rem; color: var(--fg-mute); margin-top: 3px; }
@media (max-width: 560px) { .deploy__row { grid-template-columns: 40px 1fr; } .deploy__row .stamp { grid-column: 2; justify-self: start; } }

/* ---------------------------------------------------------------------
   Five-layer flow diagram (architecture / platform)
   --------------------------------------------------------------------- */
.arch { display: grid; gap: 0; border: 1px solid var(--line); counter-reset: layer; }
.layer { position: relative; display: grid; grid-template-columns: 64px 1fr; border-bottom: 1px solid var(--line); background: var(--panel); }
.layer:last-child { border-bottom: 0; }
.layer__no { counter-increment: layer; display: grid; place-items: center; font: 500 0.78rem/1 var(--mono); color: var(--fg-mute); border-right: 1px solid var(--line); background: var(--panel-2); }
.layer__no::before { content: counter(layer, decimal-leading-zero); }
.layer__body { padding: clamp(18px, 2.4vw, 28px); }
.layer__k { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 7px; }
.layer h3 { font-size: 1.16rem; font-weight: 600; letter-spacing: -0.015em; margin-bottom: 6px; }
.layer p { font-size: 0.9rem; color: var(--fg-mute); max-width: 62ch; }
.layer--mark { background: var(--panel-2); }
.layer--mark .layer__no { background: var(--off); color: var(--black); }
.layer--mark .layer__body { box-shadow: inset 3px 0 0 var(--amber); }
.layer--mark .layer__k { color: var(--amber); }
.layer__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.tag { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.06em; color: var(--fg-mute); border: 1px solid var(--line); padding: 5px 8px; }

/* ---------------------------------------------------------------------
   CTASection — briefing request
   --------------------------------------------------------------------- */
.cta { text-align: center; }
.cta .mark { width: 42px; height: 42px; margin: 0 auto 24px; }
.cta h2 { margin-bottom: 18px; }
.cta .lede { margin: 0 auto 30px; }
.cta__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

/* Forms */
.form { display: grid; gap: 14px; max-width: 460px; }
.field { display: grid; gap: 7px; text-align: left; }
.field label { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-mute); }
.field input, .field select, .field textarea { background: transparent; color: var(--fg); border: 1px solid var(--line); padding: 13px 14px; font-size: 0.95rem; transition: border-color 0.18s var(--ease); width: 100%; }
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--fg); outline: none; }
.field input::placeholder, .field textarea::placeholder { color: var(--fg-mute); }
.field select { -webkit-appearance: none; appearance: none; }
.form__note { font: 500 0.74rem/1.4 var(--mono); letter-spacing: 0.02em; color: var(--fg-mute); }
.form__note.is-ok { color: var(--green); }

/* ---------------------------------------------------------------------
   Footer
   --------------------------------------------------------------------- */
.foot { border-top: 1px solid var(--line); padding-block: 52px 30px; }
.foot__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 32px; margin-bottom: 40px; }
@media (max-width: 720px) { .foot__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px) { .foot__grid { grid-template-columns: 1fr; } }
.foot__brand { display: inline-flex; align-items: center; gap: 11px; margin-bottom: 16px; }
.foot__brand .mark { width: 24px; height: 24px; }
.foot__what { font-size: 0.86rem; color: var(--fg-mute); max-width: 42ch; }
.foot__col h4 { font: 500 0.66rem/1 var(--mono); letter-spacing: 0.16em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 14px; }
.foot__col a { display: block; font-size: 0.88rem; color: var(--fg-mute); padding-block: 5px; transition: color 0.16s var(--ease); }
.foot__col a:hover { color: var(--fg); }
.foot__bar { display: flex; flex-wrap: wrap; gap: 8px 22px; justify-content: space-between; padding-top: 22px; border-top: 1px solid var(--line-soft); }
.foot__bar span { font: 500 0.7rem/1.5 var(--mono); letter-spacing: 0.04em; color: var(--fg-mute); }

/* ---------------------------------------------------------------------
   Interior page hero + rich text
   --------------------------------------------------------------------- */
.phero { padding-block: clamp(48px, 7vw, 92px) clamp(36px, 5vw, 60px); }
.phero .docbar { margin-bottom: clamp(24px, 4vw, 40px); }
.phero .label { margin-bottom: 20px; }
.phero h1 { margin-bottom: 20px; }
.phero .lede { max-width: 66ch; }

.rich { max-width: 70ch; }
.rich p { color: var(--fg-mute); margin-bottom: 1.1em; }
.rich h3 { font-size: 1.2rem; margin: 1.6em 0 0.5em; }
.rich ul { color: var(--fg-mute); padding-left: 1.1em; margin-bottom: 1.1em; }
.rich li { margin-bottom: 0.4em; }

/* ---------------------------------------------------------------------
   Reveal-on-scroll
   --------------------------------------------------------------------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* utility */
.mt-s { margin-top: 18px; }
.mt-m { margin-top: 30px; }
.mt-l { margin-top: 44px; }
.center { text-align: center; }
