/* ============================================================
   AEGIS — marketing site styles
   Page-specific patterns for AEGIS Website.html
   Token + primitives in brand/aegis.css
   ============================================================ */

/* ===== Hero ===== */
.hero { padding: 88px var(--gutter) 80px; border-bottom: 1px solid var(--line); position: relative; overflow: hidden; }
.hero-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 80px; align-items: center; }
.hero h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(44px, 5.2vw, 80px); line-height: 0.95; letter-spacing: -0.03em;
  margin: 22px 0 28px; color: var(--navy);
}
.hero h1 em { font-style: normal; color: var(--steel); }
.hero .lede { font-size: 19px; line-height: 1.55; max-width: 50ch; margin: 0 0 32px; color: var(--ink); opacity: 0.78; }
.hero .install {
  background: var(--navy-2); color: #cbd6e9; font-family: var(--font-mono); font-size: 13.5px;
  padding: 16px 20px; margin: 0 0 32px; display: flex; align-items: center; gap: 14px; max-width: 600px;
  border-left: 3px solid var(--steel);
}
.hero .install .dollar { color: var(--steel-2); user-select: none; }
.hero .install .s { color: #e6c98a; }
.hero .install .copy { margin-left: auto; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.45); border: 1px solid rgba(255,255,255,0.15); padding: 4px 8px; cursor: default; }
.hero .cta-row { display: flex; gap: 14px; align-items: center; margin-bottom: 40px; flex-wrap: wrap; }

.hero-marquee {
  border-top: 1px solid var(--line); padding-top: 22px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted);
  display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: center;
}
.hero-marquee .lbl { color: var(--navy); font-weight: 500; }
.hero-marquee .frames { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; opacity: 0.85; }
.hero-marquee .fw { font-family: var(--font-display); font-weight: 600; letter-spacing: 0.04em; font-size: 15px; color: var(--navy); opacity: 0.55; text-transform: none; }

/* Hero product visual */
.hero-visual { position: relative; aspect-ratio: 1 / 1; max-width: 620px; margin-left: auto; }
.hero-visual .frame {
  background: #fff; border: 1px solid var(--line); height: 100%; width: 100%;
  display: grid; grid-template-rows: auto 1fr; overflow: hidden;
  box-shadow: 0 1px 0 var(--line), 22px 22px 0 var(--paper-2);
}
.hero-visual .fr-bar {
  display: flex; justify-content: space-between; align-items: center; padding: 12px 18px;
  border-bottom: 1px solid var(--line); font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted);
}
.hero-visual .fr-bar .dots { display: flex; gap: 6px; }
.hero-visual .fr-bar .dots i { width: 8px; height: 8px; border-radius: 50%; background: var(--line-2); display: block; }
.hero-visual .fr-body { padding: 26px; display: grid; gap: 18px; grid-template-rows: auto 1fr auto; }

.agent-card { border: 1px solid var(--line); padding: 14px 18px; display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center; }
.agent-card .av { width: 30px; height: 30px; background: var(--navy); color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 12px; display: flex; align-items: center; justify-content: center; }
.agent-card .n { font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--navy); }
.agent-card .x { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); letter-spacing: 0.06em; }

.checks { display: grid; gap: 6px; }
.check { display: grid; grid-template-columns: 18px 1fr auto; gap: 12px; align-items: center; padding: 9px 14px; font-family: var(--font-mono); font-size: 12px; border-bottom: 1px dashed var(--line); }
.check:last-child { border-bottom: 0; }
.check .icon { color: var(--good); font-weight: 700; }
.check.deny .icon { color: var(--danger); }
.check .lbl { color: var(--navy); }
.check .lat { color: var(--muted); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }

.verdict { display: grid; grid-template-columns: 1fr auto; align-items: center; padding: 12px 16px; background: var(--paper-2); border-left: 3px solid var(--steel); font-family: var(--font-mono); font-size: 11px; }
.verdict .v { color: var(--navy); }
.verdict .v b { font-family: var(--font-display); font-weight: 700; color: var(--good); font-size: 13px; letter-spacing: 0.04em; }
.verdict .x { color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }

/* ===== Three pillars ===== */
.pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; background: var(--navy); border-left: 1px solid var(--navy-2); }
.pillar { padding: 40px 36px; border-right: 1px solid rgba(255,255,255,0.06); color: #fff; display: grid; grid-template-rows: auto auto auto 1fr; gap: 14px; min-height: 380px; }
.pillar:last-child { border-right: 0; }
.pillar .num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--steel-2); }
.pillar h3 { font-family: var(--font-display); font-weight: 700; font-size: 32px; letter-spacing: -0.025em; margin: 0; color: #fff; line-height: 0.95; }
.pillar .question { font-family: var(--font-display); font-style: italic; font-weight: 500; font-size: 17px; color: var(--steel-3); line-height: 1.35; letter-spacing: -0.005em; margin: 0; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.pillar p { font-size: 14.5px; color: rgba(255,255,255,0.78); line-height: 1.62; margin: 0; }
.pillar p b { font-weight: 600; color: #fff; }

/* ===== Risk cards ===== */
.problem .risk-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.risk { background: #fff; border: 1px solid var(--line); padding: 30px 28px; display: grid; grid-template-rows: auto auto 1fr; gap: 12px; min-height: 280px; }
.risk .n { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--steel); }
.risk h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.015em; color: var(--navy); margin: 0; line-height: 1.15; }
.risk p { font-size: 14.5px; color: var(--muted); line-height: 1.6; margin: 0; }

/* ===== Stack (Layer 4) ===== */
.stack { display: grid; gap: 8px; max-width: 720px; margin: 0 auto 40px; }
.stack .layer { display: grid; grid-template-columns: 60px 1fr auto; gap: 16px; align-items: center; padding: 16px 22px; background: #fff; border: 1px solid var(--line); }
.stack .layer.aegis { background: var(--navy); color: #fff; border-color: var(--navy); }
.stack .layer .num { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; color: var(--muted); }
.stack .layer.aegis .num { color: var(--steel-2); }
.stack .layer .nm { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--navy); letter-spacing: -0.01em; }
.stack .layer.aegis .nm { color: #fff; }
.stack .layer .nm small { display: block; font-family: var(--font-body); font-weight: 400; font-size: 12.5px; color: var(--muted); margin-top: 2px; letter-spacing: 0; }
.stack .layer.aegis .nm small { color: var(--steel-3); }
.stack .layer .ex { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.06em; text-transform: uppercase; }
.stack .layer.aegis .ex { color: rgba(255,255,255,0.55); }

.section-cap { text-align: center; font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; margin: 0 0 56px; }

/* ===== "Doing nothing" callout ===== */
.nothing-callout {
  display: grid; grid-template-columns: 1fr 1.3fr; gap: 56px; align-items: start;
  background: var(--paper-2); border-left: 3px solid var(--steel); padding: 40px 44px; margin-top: 56px;
}
.nothing-callout .left .x { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 14px; }
.nothing-callout .left h3 { font-family: var(--font-display); font-weight: 700; font-size: 32px; line-height: 1; letter-spacing: -0.025em; color: var(--navy); margin: 0; }
.nothing-callout .left h3 em { font-style: italic; color: var(--steel); }
.nothing-callout .right p { font-size: 15px; line-height: 1.65; color: var(--ink); margin: 0 0 18px; }
.nothing-callout .right ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.nothing-callout .right ul li { font-size: 14px; color: var(--ink); padding-left: 22px; position: relative; line-height: 1.5; }
.nothing-callout .right ul li::before { content: "—"; position: absolute; left: 0; color: var(--danger); }

/* ===== Buyers ===== */
.buyers { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; background: #fff; border-left: 1px solid var(--line); border-top: 1px solid var(--line); }
.buyer { padding: 32px 28px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); display: grid; grid-template-rows: auto auto auto auto 1fr auto; gap: 12px; min-height: 360px; }
.buyer.primary { background: var(--navy); color: #fff; }
.buyer .role { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); }
.buyer.primary .role { color: var(--steel-2); }
.buyer h3 { font-family: var(--font-display); font-weight: 700; font-size: 28px; color: var(--navy); letter-spacing: -0.02em; margin: 0; line-height: 0.95; }
.buyer.primary h3 { color: #fff; }
.buyer .tag { font-family: var(--font-mono); font-size: 10px; padding: 3px 8px; background: var(--paper-2); color: var(--muted); letter-spacing: 0.1em; text-transform: uppercase; align-self: flex-start; }
.buyer.primary .tag { background: var(--steel); color: #fff; }
.buyer p { font-size: 13.5px; color: var(--muted); line-height: 1.6; margin: 0; }
.buyer.primary p { color: rgba(255,255,255,0.75); }
.buyer .trig { padding-top: 14px; border-top: 1px dashed var(--line); font-family: var(--font-mono); font-size: 10.5px; color: var(--navy); letter-spacing: 0.06em; text-transform: uppercase; }
.buyer.primary .trig { border-top-color: rgba(255,255,255,0.12); color: var(--steel-2); }
.buyer .trig b { font-family: var(--font-body); font-weight: 600; color: var(--navy); letter-spacing: 0; text-transform: none; font-size: 13px; display: block; margin-top: 4px; }
.buyer.primary .trig b { color: #fff; }

/* ===== Outcomes ===== */
.outcomes { display: grid; grid-template-columns: repeat(5, 1fr); background: #fff; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.outcomes > .cell { padding: 30px 24px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); display: grid; grid-template-rows: auto auto 1fr; gap: 16px; min-height: 280px; }
.outcomes .num { font-family: var(--font-mono); font-size: 10.5px; color: var(--steel); letter-spacing: 0.14em; }
.outcomes h3 { font-family: var(--font-display); font-weight: 600; font-size: 20px; color: var(--navy); letter-spacing: -0.01em; margin: 0; line-height: 1.15; }
.outcomes p { font-size: 13.5px; color: var(--muted); line-height: 1.6; margin: 0; }

/* ===== How it works ===== */
.how { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 64px; align-items: start; }
.how-steps { display: flex; flex-direction: column; gap: 22px; }
.how-step { display: grid; grid-template-columns: 40px 1fr; gap: 20px; }
.how-step .n { width: 36px; height: 36px; border: 1px solid var(--navy); color: var(--navy); display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-weight: 700; font-size: 16px; }
.how-step.active .n { background: var(--navy); color: #fff; }
.how-step h4 { font-family: var(--font-display); font-weight: 600; font-size: 21px; color: var(--navy); letter-spacing: -0.015em; margin: 0 0 8px; }
.how-step p { font-size: 14.5px; color: var(--muted); line-height: 1.6; margin: 0; }
.how-step .tag { font-family: var(--font-mono); font-size: 10.5px; color: var(--steel); letter-spacing: 0.08em; text-transform: uppercase; margin-top: 8px; display: inline-block; }

/* ===== AIM tier model ===== */
.aim-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
.tier-list { display: grid; gap: 12px; }
.tier-card { display: grid; grid-template-columns: 56px 1fr auto; gap: 18px; align-items: center; padding: 20px 22px; background: #fff; border: 1px solid var(--line); }
.tier-card .t-num { font-family: var(--font-display); font-weight: 700; font-size: 36px; letter-spacing: -0.03em; line-height: 1; color: var(--navy); }
.tier-card.t-0 .t-num { color: var(--danger); }
.tier-card.t-1 .t-num { color: var(--warn); }
.tier-card.t-2 .t-num { color: var(--steel); }
.tier-card.t-3 .t-num { color: var(--good); }
.tier-card .t-nm { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--navy); letter-spacing: -0.01em; }
.tier-card .t-nm small { display: block; font-family: var(--font-body); font-weight: 400; font-size: 13px; color: var(--muted); margin-top: 2px; letter-spacing: 0; line-height: 1.45; }
.tier-card .t-tag { font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.1em; text-transform: uppercase; }

.aim-side { display: grid; gap: 16px; }
.aim-side .card { background: #fff; border: 1px solid var(--line); padding: 22px 26px; }
.aim-side .card h4 { font-family: var(--font-display); font-weight: 600; font-size: 16px; color: var(--navy); letter-spacing: -0.005em; margin: 0 0 6px; }
.aim-side .card p { font-size: 13.5px; color: var(--muted); line-height: 1.6; margin: 0; }

/* ===== Architecture / Zones ===== */
.zones-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px; align-items: start; }
.zones { background: var(--navy-2); padding: 36px; border: 1px solid var(--navy-2); }
.zones .key { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-bottom: 20px; }
.zones .key b { color: var(--steel-2); font-weight: 500; }
.zone-row { display: grid; grid-template-columns: 110px 1fr; gap: 18px; padding: 18px 0; border-bottom: 1px solid rgba(255,255,255,0.06); align-items: start; }
.zone-row:last-child { border-bottom: 0; }
.zone-row .zid { display: flex; flex-direction: column; gap: 4px; }
.zone-row .zid .z { font-family: var(--font-display); font-weight: 700; font-size: 24px; color: #fff; letter-spacing: -0.02em; }
.zone-row .zid .zx { font-family: var(--font-mono); font-size: 9.5px; color: var(--steel-2); letter-spacing: 0.14em; text-transform: uppercase; }
.zone-row .zname { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: #fff; letter-spacing: -0.01em; }
.zone-row .zdesc { font-size: 13.5px; color: rgba(255,255,255,0.7); line-height: 1.6; margin-top: 6px; }
.zone-row .ztags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.zone-row .ztag { font-family: var(--font-mono); font-size: 10px; padding: 4px 8px; background: rgba(46,117,182,0.16); color: var(--steel-3); letter-spacing: 0.06em; }

.arch-side { display: grid; gap: 22px; }
.arch-card { background: #fff; border: 1px solid var(--line); padding: 26px; }
.arch-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; color: var(--navy); letter-spacing: -0.01em; margin: 0 0 8px; }
.arch-card p { font-size: 14px; color: var(--muted); line-height: 1.6; margin: 0; }
.arch-card .x { font-family: var(--font-mono); font-size: 10.5px; color: var(--steel); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 6px; display: block; }

/* ===== Enforcement plane ===== */
.enforce-grid { display: grid; grid-template-columns: repeat(4, 1fr); background: #fff; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.enforce-grid > .cell { padding: 28px 24px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); display: grid; grid-template-rows: auto auto auto 1fr auto; gap: 10px; min-height: 280px; }
.enforce-grid .num { font-family: var(--font-mono); font-size: 10.5px; color: var(--steel); letter-spacing: 0.14em; }
.enforce-grid h3 { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--navy); letter-spacing: -0.005em; margin: 0; line-height: 1.2; }
.enforce-grid p { font-size: 13px; color: var(--muted); line-height: 1.55; margin: 0; }
.enforce-grid .lat { font-family: var(--font-mono); font-size: 10px; color: var(--navy); letter-spacing: 0.06em; padding-top: 8px; border-top: 1px dashed var(--line); margin-top: auto; }
.enforce-grid .lat b { color: var(--steel); font-weight: 600; }

/* ===== CCR ===== */
.ccr-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 56px; align-items: start; }
.ccr-viz { background: #fff; border: 1px solid var(--line); padding: 28px; }
.ccr-viz .head { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 20px; }
.ccr-viz .head .t { font-family: var(--font-display); font-weight: 600; font-size: 17px; color: var(--navy); letter-spacing: -0.01em; }
.ccr-viz .head .x { font-family: var(--font-mono); font-size: 10.5px; color: var(--good); letter-spacing: 0.08em; text-transform: uppercase; }
.ccr-viz .head .x::before { content: "● "; }
.ccr-chain { display: grid; gap: 0; border-left: 2px solid var(--steel); margin-left: 8px; padding-left: 24px; }
.ccr-block { position: relative; padding: 12px 0; border-bottom: 1px dashed var(--line); }
.ccr-block:last-child { border-bottom: 0; }
.ccr-block::before { content: ""; position: absolute; left: -31px; top: 17px; width: 10px; height: 10px; background: var(--paper); border: 2px solid var(--steel); border-radius: 50%; }
.ccr-block.signed::before { background: var(--steel); }
.ccr-block .hd { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; color: var(--navy); }
.ccr-block .hd b { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.005em; font-size: 13px; }
.ccr-block .sub { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted); margin-top: 4px; word-break: break-all; }
.ccr-block .meta { display: flex; gap: 12px; margin-top: 6px; font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; text-transform: uppercase; align-items: center; }
.ccr-block .meta .pill { padding: 1px 6px; font-size: 9.5px; }

.ccr-props { display: grid; gap: 14px; }
.ccr-prop { display: grid; grid-template-columns: 22px 1fr; gap: 14px; align-items: start; padding: 16px 18px; background: var(--paper-2); border-left: 2px solid var(--steel); }
.ccr-prop .b { color: var(--steel); font-family: var(--font-mono); font-weight: 600; font-size: 15px; padding-top: 2px; }
.ccr-prop h4 { font-family: var(--font-display); font-weight: 600; font-size: 16px; color: var(--navy); letter-spacing: -0.005em; margin: 0 0 4px; }
.ccr-prop p { font-size: 13.5px; color: var(--muted); line-height: 1.55; margin: 0; }

/* ===== Registry dashboard ===== */
.registry {
  background: #fff; border: 1px solid var(--line);
  display: grid; grid-template-columns: 240px 1fr; min-height: 720px;
}
.reg-side { background: var(--navy-2); color: #cbd6e9; padding: 18px; display: flex; flex-direction: column; gap: 4px; }
.reg-side .ws { display: flex; align-items: center; gap: 10px; padding: 8px 6px; margin-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,0.08); padding-bottom: 14px; }
.reg-side .ws img { width: 22px; height: 22px; filter: brightness(0) invert(1); }
.reg-side .ws .nm { font-family: var(--font-display); font-weight: 700; letter-spacing: 0.12em; font-size: 12px; }
.reg-side .ws .nm span { color: var(--steel-2); }
.reg-side .grp { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.16em; color: rgba(255,255,255,0.4); text-transform: uppercase; padding: 14px 6px 8px; }
.reg-side .item { padding: 8px 10px; font-size: 13px; color: rgba(255,255,255,0.78); border-radius: 2px; display: flex; justify-content: space-between; align-items: center; cursor: default; }
.reg-side .item:hover { background: rgba(255,255,255,0.04); }
.reg-side .item.active { background: rgba(46,117,182,0.18); color: #fff; box-shadow: inset 2px 0 0 var(--steel); }
.reg-side .item .badge { font-family: var(--font-mono); font-size: 9.5px; color: var(--steel-2); }

.reg-main { padding: 26px 32px; display: grid; grid-template-rows: auto auto auto 1fr; gap: 20px; background: #fff; }
.reg-h { display: flex; justify-content: space-between; align-items: baseline; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.reg-h .title { font-family: var(--font-display); font-weight: 600; font-size: 22px; color: var(--navy); letter-spacing: -0.015em; }
.reg-h .crumb { font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.08em; text-transform: uppercase; }
.reg-h .crumb b { color: var(--navy); font-weight: 500; }
.reg-h .crumb b.signal { color: var(--steel); }

.reg-stats { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.reg-stats .s { padding: 14px 16px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.reg-stats .s .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.reg-stats .s .v { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--navy); letter-spacing: -0.015em; margin-top: 4px; line-height: 1; }
.reg-stats .s .v sub { font-family: var(--font-body); font-weight: 500; font-size: 11px; color: var(--good); vertical-align: middle; margin-left: 6px; }
.reg-stats .s .v sub.signal { color: var(--steel); }
.reg-stats .s .v sub.warn { color: var(--warn); }

/* Topology panel */
.topology {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0; border: 1px solid var(--line); background: var(--paper-2); position: relative;
}
.topology .col { padding: 18px 18px 16px; border-right: 1px solid var(--line); background: #fff; }
.topology .col:last-child { border-right: 0; }
.topology .col h6 { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin: 0 0 14px; font-weight: 500; }
.topology .node { padding: 10px 12px; background: var(--paper); border: 1px solid var(--line); margin-bottom: 8px; font-size: 12px; display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center; }
.topology .node .nm { font-family: var(--font-display); font-weight: 600; color: var(--navy); font-size: 13px; letter-spacing: -0.005em; }
.topology .node .meta { font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.04em; }
.topology .node .st { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; padding: 2px 6px; }
.topology .node.governed { border-left: 2px solid var(--good); }
.topology .node.governed .st { color: var(--good); }
.topology .node.anomaly { border-left: 2px solid var(--warn); background: rgba(181,114,42,0.04); }
.topology .node.anomaly .st { color: var(--warn); }
.topology .node.blocked { border-left: 2px solid var(--danger); background: rgba(181,58,51,0.04); }
.topology .node.blocked .st { color: var(--danger); }
.topology .node.shadow { border-left: 2px dashed var(--muted); background: var(--paper-2); }
.topology .node.shadow .nm { color: var(--muted); font-style: italic; }
.topology .node.shadow .st { color: var(--muted); }

/* Registry table */
.reg-table { border: 1px solid var(--line); }
.reg-table .th, .reg-table .tr { display: grid; grid-template-columns: 1.4fr 90px 1fr 110px 80px 80px 80px; gap: 12px; padding: 12px 16px; align-items: center; }
.reg-table .th { background: var(--paper-2); font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); border-bottom: 1px solid var(--line); }
.reg-table .tr { border-bottom: 1px solid var(--line); font-size: 13px; font-family: var(--font-mono); color: var(--navy); }
.reg-table .tr:last-child { border-bottom: 0; }
.reg-table .tr:hover { background: var(--paper); }
.reg-table .tr .agent { font-family: var(--font-body); font-weight: 500; color: var(--navy); display: flex; flex-direction: column; gap: 2px; }
.reg-table .tr .agent small { font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.06em; }
.reg-table .tr .tier { font-family: var(--font-display); font-weight: 700; font-size: 14px; padding: 4px 10px; text-align: center; border-radius: 2px; letter-spacing: -0.005em; }
.reg-table .tr .tier.t0 { background: rgba(181,58,51,0.12); color: var(--danger); }
.reg-table .tr .tier.t1 { background: rgba(181,114,42,0.14); color: var(--warn); }
.reg-table .tr .tier.t2 { background: rgba(46,117,182,0.14); color: var(--steel); }
.reg-table .tr .tier.t3 { background: #E4F1E8; color: var(--good); }
.reg-table .tr .owner { font-family: var(--font-body); color: var(--muted); font-size: 12.5px; }
.reg-table .tr .when { font-family: var(--font-mono); font-size: 11px; color: var(--muted); }
.reg-table .tr .score { font-family: var(--font-mono); color: var(--navy); font-weight: 500; }

/* ===== MCP Tunneling callout ===== */
.mcp-callout { background: var(--paper-2); padding: 40px; border-left: 3px solid var(--steel); margin-top: 56px; }
.mcp-callout .inner { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: start; }
.mcp-callout .x { font-family: var(--font-mono); font-size: 11px; color: var(--steel); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 10px; }
.mcp-callout h3 { font-family: var(--font-display); font-weight: 700; font-size: 26px; color: var(--navy); letter-spacing: -0.02em; margin: 0 0 12px; line-height: 1.1; }
.mcp-callout h3 em { font-style: italic; color: var(--steel); }
.mcp-callout p { font-size: 14.5px; color: var(--muted); line-height: 1.6; margin: 0; }
.mcp-callout ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.mcp-callout ul li { display: grid; grid-template-columns: 18px 1fr; gap: 14px; align-items: start; font-size: 13.5px; line-height: 1.55; color: var(--ink); }
.mcp-callout ul li::before { content: "+"; color: var(--steel); font-family: var(--font-mono); font-weight: 600; }
.mcp-callout ul li b { font-family: var(--font-display); font-weight: 600; color: var(--navy); display: block; margin-bottom: 2px; font-size: 14px; letter-spacing: -0.005em; }

/* ===== Threats table wrap ===== */
.threat-table-wrap { background: #fff; border: 1px solid var(--line); overflow-x: auto; }

/* ===== Resilience matrix ===== */
.resilience-grid { display: grid; grid-template-columns: repeat(2, 1fr); background: var(--navy-2); border-top: 1px solid rgba(255,255,255,0.06); border-left: 1px solid rgba(255,255,255,0.06); }
.resilience-grid > .cell { padding: 22px 24px; border-right: 1px solid rgba(255,255,255,0.06); border-bottom: 1px solid rgba(255,255,255,0.06); color: rgba(255,255,255,0.85); display: grid; grid-template-columns: 1fr 1fr; gap: 16px; min-height: 100px; align-items: start; }
.resilience-grid .left { display: flex; flex-direction: column; gap: 6px; }
.resilience-grid .nm { font-family: var(--font-display); font-weight: 600; font-size: 15px; color: #fff; letter-spacing: -0.005em; }
.resilience-grid .tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(255,255,255,0.55); }
.resilience-grid .right { font-size: 13px; line-height: 1.55; color: rgba(255,255,255,0.82); }
.resilience-grid .cell.never .nm { color: #ff8d85; }
.resilience-grid .cell.never .right b { color: #ff8d85; }

/* ===== Compliance ===== */
.compliance-grid { display: grid; grid-template-columns: repeat(5, 1fr); background: #fff; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.compliance-grid > .cell { padding: 26px 22px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); min-height: 220px; display: grid; grid-template-rows: auto auto 1fr auto; gap: 8px; }
.compliance-grid .x { font-family: var(--font-mono); font-size: 10px; color: var(--muted); letter-spacing: 0.12em; text-transform: uppercase; }
.compliance-grid .nm { font-family: var(--font-display); font-weight: 700; font-size: 20px; color: var(--navy); letter-spacing: -0.015em; line-height: 1.05; }
.compliance-grid p { font-size: 12.5px; color: var(--muted); line-height: 1.5; margin: 0; }
.compliance-grid .st { font-family: var(--font-mono); font-size: 10.5px; color: var(--good); letter-spacing: 0.08em; }
.compliance-grid .st::before { content: "● "; }
.compliance-grid .st.partial { color: var(--warn); }

.siem-block { margin-top: 40px; padding: 28px 32px; background: var(--navy); color: #fff; }
.siem-block .inner { display: grid; grid-template-columns: 1fr 1.4fr; gap: 40px; align-items: start; }
.siem-block .x { font-family: var(--font-mono); font-size: 11px; color: var(--steel-2); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 10px; }
.siem-block h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.015em; line-height: 1.2; margin: 0; color: #fff; }
.siem-block .formats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }

/* ===== Roadmap ===== */
.roadmap { display: grid; grid-template-columns: repeat(5, 1fr); border-left: 1px solid var(--line); border-top: 1px solid var(--line); background: #fff; }
.phase { padding: 28px 22px 24px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); display: flex; flex-direction: column; gap: 14px; min-height: 340px; }
.phase.active { background: var(--navy); color: #fff; }
.phase .num { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; color: var(--steel); text-transform: uppercase; }
.phase.active .num { color: var(--steel-2); }
.phase h3 { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--navy); letter-spacing: -0.015em; margin: 0; line-height: 1; }
.phase.active h3 { color: #fff; }
.phase .stage { font-family: var(--font-mono); font-size: 10px; padding: 3px 8px; background: var(--paper-2); color: var(--muted); letter-spacing: 0.1em; text-transform: uppercase; align-self: flex-start; }
.phase.active .stage { background: var(--steel); color: #fff; }
.phase ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.phase ul li { font-size: 12.5px; line-height: 1.45; color: var(--ink); padding-left: 14px; position: relative; }
.phase.active ul li { color: rgba(255,255,255,0.82); }
.phase ul li::before { content: "+"; position: absolute; left: 0; top: 0; font-family: var(--font-mono); color: var(--steel); font-weight: 600; }
.phase.active ul li::before { color: var(--steel-2); }

/* ===== Closer ===== */
.closer { background: var(--navy); color: #fff; padding: 120px var(--gutter) 100px; border-bottom: 0; }
.closer-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 80px; align-items: end; }
.closer h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(48px, 6vw, 84px); line-height: 0.95; letter-spacing: -0.03em; margin: 0; color: #fff; }
.closer h2 em { font-style: normal; color: var(--steel-2); }
.closer p { font-size: 17px; color: rgba(255,255,255,0.72); line-height: 1.6; max-width: 44ch; margin: 24px 0 0; }
.closer .cta-block { display: flex; flex-direction: column; gap: 14px; align-items: flex-start; }
.closer .meta { margin-top: 24px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255,255,255,0.5); }

/* ===== Footer ===== */
footer.site { background: var(--navy-2); color: rgba(255,255,255,0.7); padding: 64px var(--gutter) 32px; }
.foot-inner { max-width: var(--maxw); margin: 0 auto; display: grid; grid-template-columns: 1.4fr repeat(4, 1fr); gap: 40px; }
.foot-brand img { height: 30px; margin-bottom: 16px; filter: brightness(0) invert(1); opacity: 0.9; }
.foot-brand .wm { font-family: var(--font-display); font-weight: 700; letter-spacing: 0.14em; font-size: 15px; color: #fff; }
.foot-brand .wm span { color: var(--steel-2); }
.foot-brand p { font-size: 13.5px; line-height: 1.6; margin: 16px 0 0; max-width: 32ch; }
.foot-brand .by { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.5); margin-top: 12px; }
.foot-col h6 { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: rgba(255,255,255,0.4); margin: 0 0 14px; font-weight: 500; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.foot-col ul a { font-size: 13.5px; color: rgba(255,255,255,0.78); }
.foot-col ul a:hover { color: #fff; }
.foot-bot { max-width: var(--maxw); margin: 56px auto 0; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.08); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(255,255,255,0.4); text-transform: uppercase; }

/* ===== FAQ ===== */
.faq-list { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.faq-item { padding: 30px 34px 32px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #fff; }
.faq-item h3 { font-family: var(--font-display); font-weight: 600; font-size: 19px; line-height: 1.3; color: var(--navy); letter-spacing: -0.015em; margin: 0 0 12px; }
.faq-item p { font-size: 14.5px; line-height: 1.65; color: var(--muted); margin: 0; text-wrap: pretty; }
.faq-item p b { color: var(--ink); font-weight: 600; }

/* ===== Responsive ===== */
@media (max-width: 1100px) {
  .hero-inner, .how, .ccr-grid, .zones-grid, .aim-grid, .closer-inner, .mcp-callout .inner, .nothing-callout, .siem-block .inner { grid-template-columns: 1fr; gap: 48px; }
  .problem .risk-grid { grid-template-columns: 1fr; }
  .pillars { grid-template-columns: 1fr; }
  .outcomes { grid-template-columns: repeat(2, 1fr); }
  .enforce-grid { grid-template-columns: repeat(2, 1fr); }
  .compliance-grid { grid-template-columns: repeat(2, 1fr); }
  .faq-list { grid-template-columns: 1fr; }
  .roadmap { grid-template-columns: 1fr; }
  .resilience-grid { grid-template-columns: 1fr; }
  .buyers { grid-template-columns: 1fr 1fr; }
  .foot-inner { grid-template-columns: 1fr 1fr; }
  .registry { grid-template-columns: 1fr; }
  .reg-side { display: none; }
  .reg-stats { grid-template-columns: repeat(2, 1fr); }
  .siem-block .formats { grid-template-columns: repeat(2, 1fr); }
}
