/* ===================================================================
   ARGOS CENTER — Program Operating System
   High-fidelity executive command center · design system
   Aesthetic: intelligence-fusion / defense program executive office
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Saira:wght@300;400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* ---- surfaces (matte black → graphite → deep navy) ---- */
  --bg:#06090f;
  --s0:#080c13;
  --s1:#0b1019;
  --s2:#0f1622;          /* primary panel */
  --s3:#141d2c;          /* raised / hover */
  --s4:#1a2536;          /* elevated */
  --navy:#0a1526;

  /* ---- hairlines ---- */
  --line:rgba(126,151,188,.12);
  --line-2:rgba(126,151,188,.20);
  --line-3:rgba(126,151,188,.32);

  /* ---- ink ---- */
  --ink:#e9eef7;
  --ink-2:#a6b3c9;
  --ink-3:#6b7889;
  --ink-4:#475467;

  /* ---- accents (desaturated, defense-grade) ---- */
  --steel:#6ea6d8;  --steel-d:#3f6a96;  --steel-dim:rgba(110,166,216,.13);
  --amber:#e0a648;  --amber-d:#9d7224;  --amber-dim:rgba(224,166,72,.13);
  --green:#5cae7e;  --green-d:#377a52;  --green-dim:rgba(92,174,126,.13);
  --red:#d26b4f;    --red-d:#9a4631;    --red-dim:rgba(210,107,79,.13);

  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,monospace;
  --sans:'Saira',system-ui,-apple-system,sans-serif;
  --radius:4px;
  --shadow:0 18px 40px -20px rgba(0,0,0,.85);
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.45;
  overflow:hidden;            /* app shell owns scrolling */
}

/* atmospheric background: faint grid + vignette + grain */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    linear-gradient(var(--line) 1px,transparent 1px) 0 0/46px 46px,
    linear-gradient(90deg,var(--line) 1px,transparent 1px) 0 0/46px 46px;
  -webkit-mask-image:radial-gradient(120% 90% at 70% -10%,#000 30%,transparent 75%);
          mask-image:radial-gradient(120% 90% at 70% -10%,#000 30%,transparent 75%);
  opacity:.5;
}
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

::selection{background:rgba(110,166,216,.28);color:#fff}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#1b2738;border:2px solid var(--bg);border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#243650}
::-webkit-scrollbar-track{background:transparent}

/* ---- shared type helpers ---- */
.mono{font-family:var(--mono)}
.kicker{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.num{font-family:var(--mono);font-weight:500;font-variant-numeric:tabular-nums;letter-spacing:-.01em}

/* =================================================================
   APP SHELL  —  classification strip · rail · topbar · workspace
   ================================================================= */
.classbar{
  position:fixed;top:0;left:0;right:0;height:22px;z-index:60;
  display:flex;align-items:center;gap:18px;padding:0 14px;
  font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--amber);background:#070b12;border-bottom:1px solid var(--line-2);
}
.classbar .edge{height:100%;width:46px;flex:0 0 auto;
  background:repeating-linear-gradient(135deg,rgba(224,166,72,.5) 0 6px,transparent 6px 12px)}
.classbar .mid{flex:1;text-align:center;color:var(--ink-3)}
.classbar b{color:var(--amber)}

.app{
  position:fixed;inset:22px 0 0 0;z-index:1;
  display:grid;grid-template-columns:250px 1fr;
}

/* ---------- rail ---------- */
.rail{
  background:linear-gradient(180deg,#080c14,#070a11);
  border-right:1px solid var(--line-2);
  display:flex;flex-direction:column;min-height:0;
}
.brand{display:flex;align-items:center;gap:11px;padding:16px 16px 14px;border-bottom:1px solid var(--line)}
.brand img{width:34px;height:34px;flex:0 0 auto;filter:drop-shadow(0 0 8px rgba(110,166,216,.35))}
.brand .bt{font-weight:700;font-size:16px;letter-spacing:.16em;line-height:1}
.brand .bs{font-family:var(--mono);font-size:9.5px;letter-spacing:.24em;color:var(--steel);text-transform:uppercase;margin-top:3px}

.nav{flex:1;overflow-y:auto;padding:12px 10px;display:flex;flex-direction:column;gap:2px;min-height:0}
.nav .group{font-family:var(--mono);font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-4);padding:14px 10px 6px}
.item{
  --c:var(--steel);
  display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:var(--radius);
  color:var(--ink-2);cursor:pointer;position:relative;border:1px solid transparent;
  font-size:13.5px;letter-spacing:.01em;transition:.16s var(--ease);
}
.item .ic{width:17px;height:17px;flex:0 0 auto;opacity:.85;stroke:currentColor}
.item .lbl{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item .ct{font-family:var(--mono);font-size:10.5px;color:var(--ink-4)}
.item:hover{background:var(--s2);color:var(--ink);border-color:var(--line)}
.item.on{background:linear-gradient(90deg,var(--steel-dim),transparent);color:#fff;border-color:var(--line-2)}
.item.on::before{content:"";position:absolute;left:-1px;top:6px;bottom:6px;width:2px;background:var(--steel);
  box-shadow:0 0 10px var(--steel);border-radius:2px}
.item.on .ic{opacity:1;color:var(--steel)}
.item.on .ct{color:var(--steel)}

.rail-foot{border-top:1px solid var(--line);padding:12px 14px;display:flex;flex-direction:column;gap:9px}
.sysrow{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10.5px;color:var(--ink-3)}
.sysrow .v{color:var(--ink-2)}
.bartrack{height:4px;border-radius:3px;background:#141d2c;overflow:hidden;border:1px solid var(--line)}
.bartrack i{display:block;height:100%;background:var(--steel)}
.owner{display:flex;align-items:center;gap:9px;padding-top:3px}
.owner .av{width:26px;height:26px;border-radius:50%;flex:0 0 auto;border:1px solid var(--line-3);
  background:radial-gradient(circle at 35% 30%,#2b3c54,#101824);display:grid;place-items:center;
  font-family:var(--mono);font-size:10px;color:var(--steel);font-weight:600}
.owner .nm{font-size:12px;line-height:1.1}
.owner .rl{font-family:var(--mono);font-size:9.5px;color:var(--ink-4);letter-spacing:.1em;text-transform:uppercase}

/* ---------- topbar ---------- */
.main{display:flex;flex-direction:column;min-width:0;min-height:0}
.topbar{
  height:54px;flex:0 0 auto;display:flex;align-items:center;gap:16px;padding:0 20px;
  border-bottom:1px solid var(--line-2);background:rgba(8,12,19,.86);backdrop-filter:blur(8px);z-index:30;
}
.crumb{display:flex;align-items:baseline;gap:9px;min-width:0}
.crumb .t{font-weight:600;font-size:15px;letter-spacing:.02em;white-space:nowrap}
.crumb .s{font-family:var(--mono);font-size:11px;color:var(--ink-3);white-space:nowrap}
.cmd{
  margin-left:8px;flex:0 1 360px;display:flex;align-items:center;gap:9px;height:34px;padding:0 12px;
  border:1px solid var(--line-2);border-radius:var(--radius);background:var(--s1);color:var(--ink-3);
  cursor:text;font-size:13px;transition:.16s var(--ease)
}
.cmd:hover{border-color:var(--line-3);background:var(--s2)}
.cmd .kbd{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--ink-4);
  border:1px solid var(--line-2);border-radius:3px;padding:1px 5px}
.tb-right{margin-left:auto;display:flex;align-items:center;gap:14px}
.clock{font-family:var(--mono);font-size:11.5px;color:var(--ink-2);letter-spacing:.05em}
.clock b{color:var(--ink-4);font-weight:400}

/* status chips */
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;padding:5px 9px;border:1px solid var(--line-2);border-radius:var(--radius);
  color:var(--ink-2);background:var(--s1);white-space:nowrap}
.chip.steel{color:var(--steel);border-color:rgba(110,166,216,.4);background:var(--steel-dim)}
.chip.amber{color:var(--amber);border-color:rgba(224,166,72,.4);background:var(--amber-dim)}
.chip.green{color:var(--green);border-color:rgba(92,174,126,.4);background:var(--green-dim)}
.chip.red{color:var(--red);border-color:rgba(210,107,79,.4);background:var(--red-dim)}

.led{width:7px;height:7px;border-radius:50%;background:currentColor;flex:0 0 auto;
  box-shadow:0 0 0 0 currentColor;animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(110,166,216,.5)}70%{box-shadow:0 0 0 6px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* ---------- workspace ---------- */
.workspace{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;position:relative;scroll-behavior:smooth}
.screen{display:none}
.screen.on{display:block;animation:rise .4s var(--ease)}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.pad{padding:26px 30px 80px;max-width:1640px;margin:0 auto}

/* =================================================================
   PRIMITIVES  —  panels · sections · buttons · stats · tags
   ================================================================= */
.panel{position:relative;background:linear-gradient(180deg,var(--s2),var(--s1));border:1px solid var(--line-2);
  border-radius:6px}
.panel.tick::before,.panel.tick::after{content:"";position:absolute;width:9px;height:9px;pointer-events:none}
.panel.tick::before{top:-1px;left:-1px;border-top:1px solid var(--steel);border-left:1px solid var(--steel);opacity:.6}
.panel.tick::after{bottom:-1px;right:-1px;border-bottom:1px solid var(--steel);border-right:1px solid var(--steel);opacity:.6}
.pad-2{padding:16px}.pad-3{padding:20px}

/* section header */
.sec{margin:46px 0 18px}
.sec:first-child{margin-top:8px}
.sec-h{display:flex;align-items:flex-end;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--line-2);
  position:relative}
.sec-h .idx{font-family:var(--mono);font-size:11px;color:var(--steel);letter-spacing:.18em;
  border:1px solid var(--line-2);border-radius:3px;padding:3px 7px;background:var(--s1)}
.sec-h h2{margin:0;font-size:21px;font-weight:600;letter-spacing:.03em}
.sec-h .meta{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em}
.sec-h .grow{flex:1}
.sec-h .act{display:flex;gap:8px}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink-2);background:var(--s2);border:1px solid var(--line-2);
  border-radius:var(--radius);padding:7px 12px;cursor:pointer;transition:.16s var(--ease);white-space:nowrap}
.btn:hover{color:#fff;border-color:var(--line-3);background:var(--s3)}
.btn.pri{color:var(--steel);border-color:rgba(110,166,216,.45);background:var(--steel-dim)}
.btn.pri:hover{background:rgba(110,166,216,.2)}
.btn .ic{width:14px;height:14px;stroke:currentColor}
.btn.sm{padding:5px 9px;font-size:10px}

/* layout helpers */
.grid{display:grid;gap:14px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}.g5{grid-template-columns:repeat(5,1fr)}.g6{grid-template-columns:repeat(6,1fr)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.col{display:flex;flex-direction:column;gap:12px}
.between{display:flex;align-items:center;justify-content:space-between;gap:12px}
.spread{flex:1}

/* tag (inline status) */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  padding:3px 8px;border:1px solid var(--line-2);border-radius:3px;color:var(--ink-2);background:var(--s1);white-space:nowrap}
.tag .d{width:6px;height:6px;border-radius:50%;background:currentColor}
.tag.steel{color:var(--steel);border-color:rgba(110,166,216,.38)}
.tag.amber{color:var(--amber);border-color:rgba(224,166,72,.38)}
.tag.green{color:var(--green);border-color:rgba(92,174,126,.38)}
.tag.red{color:var(--red);border-color:rgba(210,107,79,.38)}
.tag.ghost{color:var(--ink-3)}

/* =================================================================
   SECTION 1 · EXECUTIVE STATUS LAYER (hero)
   ================================================================= */
.hero{position:relative;border:1px solid var(--line-2);border-radius:8px;overflow:hidden;
  background:linear-gradient(180deg,var(--navy),var(--s0))}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:radial-gradient(80% 120% at 88% -20%,rgba(110,166,216,.16),transparent 60%)}
.hero-top{position:relative;display:flex;align-items:flex-start;gap:24px;padding:26px 28px 22px;border-bottom:1px solid var(--line)}
.hero-id{flex:1;min-width:0}
.hero-id .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.hero-id h1{margin:0;font-size:clamp(34px,4.6vw,58px);font-weight:800;letter-spacing:.04em;line-height:.96}
.hero-id .tagline{font-family:var(--mono);font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--steel);margin-top:8px}
.hero-id .chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.hero-seal{flex:0 0 auto;width:118px;height:118px;display:grid;place-items:center;position:relative}
.hero-seal img{width:78px;height:78px;filter:drop-shadow(0 0 14px rgba(110,166,216,.5))}
.hero-seal .ring{position:absolute;inset:0;border:1px solid var(--line-3);border-radius:50%}
.hero-seal .ring.r2{inset:14px;border-style:dashed;border-color:rgba(110,166,216,.3);animation:spin 60s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

.hero-readouts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);
  border-bottom:1px solid var(--line)}
.ro{background:var(--s1);padding:16px 18px;position:relative;min-height:104px}
.ro .lab{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.ro .big{font-size:19px;font-weight:600;letter-spacing:.02em;margin-top:8px;line-height:1.1}
.ro .sub{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:4px}

/* funding gate track */
.gates{display:flex;gap:4px;margin-top:11px}
.gates i{flex:1;height:7px;border-radius:2px;background:#16202f;border:1px solid var(--line)}
.gates i.done{background:var(--green);border-color:var(--green-d)}
.gates i.now{background:var(--amber);border-color:var(--amber-d);box-shadow:0 0 8px rgba(224,166,72,.5)}
/* phase mini */
.phasemini{display:flex;gap:3px;margin-top:11px;align-items:center}
.phasemini b{flex:1;height:3px;background:#16202f;border-radius:2px}
.phasemini b.done{background:var(--steel)}
.phasemini b.now{background:var(--amber);box-shadow:0 0 8px rgba(224,166,72,.55)}
/* readiness gauge */
.gauge{display:flex;align-items:center;gap:14px;margin-top:6px}
.gauge svg{width:62px;height:62px;flex:0 0 auto;transform:rotate(-90deg)}
.gauge .gv{font-size:24px;font-weight:700;font-family:var(--mono)}
.gauge .gx{font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.1em}

/* count readouts strip */
.counts{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line)}
.cnt{background:var(--s0);padding:18px 18px;display:flex;flex-direction:column;gap:5px;position:relative;
  transition:.18s var(--ease)}
.cnt:hover{background:var(--s2)}
.cnt .lab{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.cnt .v{font-family:var(--mono);font-size:34px;font-weight:600;letter-spacing:-.02em;line-height:1}
.cnt .dl{font-family:var(--mono);font-size:10.5px;color:var(--green)}
.cnt .dl.flat{color:var(--ink-4)}
.cnt .spark{position:absolute;right:14px;bottom:16px;width:46px;height:18px;opacity:.7}

/* =================================================================
   SECTION 2 · KNOWLEDGE GRAPH LAYER (the showpiece)
   ================================================================= */
.graphwrap{position:relative;border:1px solid var(--line-2);border-radius:8px;overflow:hidden;
  background:radial-gradient(120% 120% at 50% 40%,#0c1422,#070b12 70%)}
.graph-stage{position:relative;width:100%;height:min(70vh,640px);min-height:520px}
.graph-stage svg.edges{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.graph-grid{position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    radial-gradient(circle at center,var(--line) 1px,transparent 1px) 0 0/40px 40px;
  -webkit-mask-image:radial-gradient(60% 60% at 50% 50%,#000,transparent 78%);
          mask-image:radial-gradient(60% 60% at 50% 50%,#000,transparent 78%)}
.graph-rings{position:absolute;inset:0;pointer-events:none}
.graph-rings span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);border-radius:50%;
  border:1px solid var(--line)}
.sweep{position:absolute;inset:0;pointer-events:none;z-index:1;
  background:conic-gradient(from 0deg at 50% 50%,rgba(110,166,216,.12),rgba(110,166,216,.02) 16%,transparent 26%);
  -webkit-mask-image:radial-gradient(closest-side at 50% 50%,#000 0%,#000 56%,transparent 70%);
          mask-image:radial-gradient(closest-side at 50% 50%,#000 0%,#000 56%,transparent 70%);
  animation:radar 11s linear infinite}
@keyframes radar{to{transform:rotate(360deg)}}

.gnode{position:absolute;transform:translate(-50%,-50%);display:flex;align-items:center;gap:7px;
  font-size:12px;white-space:nowrap;cursor:pointer;transition:opacity .25s var(--ease),filter .2s var(--ease);z-index:3}
.gnode .dot{width:8px;height:8px;border-radius:50%;background:var(--steel);box-shadow:0 0 8px var(--steel)}
.gnode.core{z-index:5;flex-direction:column;gap:0;width:104px;height:104px;border-radius:50%;
  justify-content:center;background:radial-gradient(circle at 42% 38%,#16273d,#0a1424);
  border:1px solid rgba(110,166,216,.5);
  box-shadow:0 0 0 6px rgba(110,166,216,.06),0 0 40px rgba(110,166,216,.35),inset 0 0 24px rgba(110,166,216,.12)}
.gnode.core .ct-core{font-weight:800;font-size:22px;letter-spacing:.12em;color:#fff}
.gnode.core .sub-core{font-family:var(--mono);font-size:8.5px;letter-spacing:.2em;color:var(--steel);margin-top:2px}
.gnode.core .dot{display:none}
.gnode.branch{padding:6px 11px 6px 9px;border-radius:30px;background:rgba(13,20,32,.92);
  border:1px solid var(--line-3);backdrop-filter:blur(2px)}
.gnode.branch .lbl{font-weight:500;letter-spacing:.02em}
.gnode.branch .ct{font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.gnode.branch[data-tone="amber"] .dot{background:var(--amber);box-shadow:0 0 8px var(--amber)}
.gnode.branch[data-tone="green"] .dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.gnode.branch[data-tone="red"] .dot{background:var(--red);box-shadow:0 0 8px var(--red)}
.gnode.leaf{width:auto}
.gnode.leaf .dot{width:5px;height:5px;background:var(--ink-3);box-shadow:none}
.gnode.leaf .lbl{font-family:var(--mono);font-size:9.5px;color:var(--ink-4)}
.gnode:hover{filter:brightness(1.25)}
.gnode.branch:hover,.gnode.branch.hot{border-color:var(--steel);box-shadow:0 0 0 1px var(--steel),0 0 22px rgba(110,166,216,.4)}
/* dim non-focused subtree */
.graph-stage.focusing .gnode.dim{opacity:.16}
.graph-stage.focusing svg.edges path.dim{opacity:.07}
svg.edges path{transition:opacity .25s var(--ease)}
svg.edges path.flow{stroke-dasharray:5 10;animation:flow 1.6s linear infinite}
@keyframes flow{to{stroke-dashoffset:-30}}

/* graph chrome */
.graph-tools{position:absolute;top:14px;left:14px;display:flex;gap:8px;z-index:8}
.graph-legend{position:absolute;bottom:14px;left:14px;display:flex;gap:14px;z-index:8;
  font-family:var(--mono);font-size:10px;color:var(--ink-3);letter-spacing:.06em}
.graph-legend span{display:inline-flex;align-items:center;gap:6px}
.graph-legend i{width:8px;height:8px;border-radius:50%}
/* inspector */
.inspector{position:absolute;top:14px;right:14px;width:236px;z-index:8;
  background:rgba(9,13,20,.92);border:1px solid var(--line-2);border-radius:6px;padding:14px;backdrop-filter:blur(8px)}
.inspector .ih{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.inspector .ih .d{width:9px;height:9px;border-radius:50%;background:var(--steel);box-shadow:0 0 8px var(--steel)}
.inspector .ih b{font-size:15px;font-weight:600;letter-spacing:.02em}
.inspector .iline{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;
  padding:5px 0;border-bottom:1px solid var(--line);color:var(--ink-3)}
.inspector .iline .v{color:var(--ink)}
.inspector .idesc{font-size:12px;color:var(--ink-2);margin:10px 0 0;line-height:1.5}
.inspector .ifoot{margin-top:12px}

/* =================================================================
   SECTION 3 · EVIDENCE LAYER  (artifact grid)
   ================================================================= */
.artifact{display:flex;flex-direction:column;gap:0;padding:0;cursor:pointer;overflow:hidden;
  transition:.18s var(--ease)}
.artifact:hover{border-color:var(--line-3);transform:translateY(-2px);box-shadow:var(--shadow)}
.artifact .top{display:flex;align-items:flex-start;gap:10px;padding:14px 15px 10px}
.artifact .ftype{width:38px;height:46px;flex:0 0 auto;border:1px solid var(--line-2);border-radius:3px;
  display:grid;place-content:center;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--steel);
  background:linear-gradient(160deg,var(--s3),var(--s1));position:relative}
.artifact .ftype::before{content:"";position:absolute;top:0;right:0;border-width:0 9px 9px 0;border-style:solid;
  border-color:transparent var(--line-2) transparent transparent}
.artifact .ti{min-width:0;flex:1}
.artifact h4{margin:0;font-size:14.5px;font-weight:600;letter-spacing:.01em;line-height:1.2}
.artifact .cat{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-top:4px}
.artifact .meta{display:flex;align-items:center;gap:8px;padding:10px 15px;border-top:1px solid var(--line);
  margin-top:auto;background:rgba(8,12,19,.5)}
.artifact .meta .upd{font-family:var(--mono);font-size:10px;color:var(--ink-4);margin-left:auto}
.conns{display:flex;align-items:center;gap:3px}
.conns i{width:5px;height:5px;border-radius:50%;background:var(--steel-d)}
.conns .n{font-family:var(--mono);font-size:10px;color:var(--ink-3);margin-left:4px}

/* =================================================================
   SECTION 4 · TIMELINE LAYER (roadmap)
   ================================================================= */
.roadmap{padding:30px 26px 22px;position:relative}
.rm-track{position:relative;height:3px;background:#16202f;border-radius:3px;margin:38px 2% 0}
.rm-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--steel-d),var(--steel));
  box-shadow:0 0 12px rgba(110,166,216,.5);border-radius:3px}
.rm-phases{position:absolute;inset:0;display:flex}
.rm-ph{flex:1;position:relative;display:flex;justify-content:center;cursor:pointer}
.rm-ph .node{position:absolute;top:-7px;width:16px;height:16px;border-radius:50%;background:var(--s0);
  border:2px solid var(--steel-d);z-index:2;transition:.18s var(--ease)}
.rm-ph.done .node{background:var(--steel);border-color:var(--steel)}
.rm-ph.now .node{background:var(--amber);border-color:var(--amber);box-shadow:0 0 0 5px rgba(224,166,72,.22),0 0 14px var(--amber)}
.rm-ph:hover .node,.rm-ph.sel .node{transform:scale(1.25)}
.rm-ph .gate{position:absolute;top:-13px;left:0;width:7px;height:7px;background:var(--s0);border:1px solid var(--amber);
  transform:rotate(45deg)}
.rm-lab{position:absolute;top:18px;left:0;right:0;text-align:center}
.rm-lab .nm{font-size:12.5px;font-weight:500;white-space:nowrap}
.rm-lab .st{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-4);margin-top:3px}
.rm-ph.done .rm-lab .st{color:var(--steel)}
.rm-ph.now .rm-lab .st{color:var(--amber)}
.rm-flag{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);white-space:nowrap;
  font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber)}
.rm-detail{margin-top:74px;border-top:1px solid var(--line);padding-top:16px;display:grid;
  grid-template-columns:1fr 1fr 1fr;gap:14px}
.rm-detail .blk .lab{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px}
.rm-detail .mil{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-2);padding:4px 0}
.rm-detail .mil .d{width:6px;height:6px;border-radius:50%;flex:0 0 auto}

/* =================================================================
   SECTION 5 · ARCHITECTURE LAYER (6-layer stack)
   ================================================================= */
.stack{display:flex;flex-direction:column;gap:7px;padding:6px 0}
.layer{display:flex;align-items:center;gap:16px;padding:14px 18px;border:1px solid var(--line-2);border-radius:5px;
  background:linear-gradient(180deg,var(--s2),var(--s1));cursor:pointer;position:relative;
  transition:.2s var(--ease);overflow:hidden}
.layer::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--steel);opacity:.35;transition:.2s}
.layer:hover,.layer.sel{border-color:var(--steel);background:linear-gradient(90deg,var(--steel-dim),var(--s2))}
.layer:hover::before,.layer.sel::before{opacity:1;box-shadow:0 0 14px var(--steel)}
.layer .lv{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--steel);width:54px;flex:0 0 auto}
.layer .lname{font-size:16px;font-weight:600;flex:0 0 auto;width:210px;letter-spacing:.01em}
.layer .ldesc{font-size:12.5px;color:var(--ink-3);flex:1;min-width:0}
.layer .lct{font-family:var(--mono);font-size:11px;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.layer .lct .d{width:6px;height:6px;border-radius:50%;background:var(--green)}
/* pyramid inset so it reads as a stack */
.stack .layer:nth-child(1){margin:0 44px}
.stack .layer:nth-child(2){margin:0 36px}
.stack .layer:nth-child(3){margin:0 28px}
.stack .layer:nth-child(4){margin:0 20px}
.stack .layer:nth-child(5){margin:0 12px}
.stack .layer:nth-child(6){margin:0 4px}

/* =================================================================
   SECTION 6 · RECENT ACTIVITY (ops log)
   ================================================================= */
.feed{display:flex;flex-direction:column}
.event{display:flex;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--line);
  position:relative;transition:.15s var(--ease)}
.event:hover{background:var(--s2)}
.event:last-child{border-bottom:none}
.event .etype{width:30px;height:30px;flex:0 0 auto;border-radius:4px;display:grid;place-items:center;
  border:1px solid var(--line-2);background:var(--s1)}
.event .etype svg{width:15px;height:15px;stroke:currentColor;fill:none}
.event.approve .etype{color:var(--green);border-color:var(--green-d);background:var(--green-dim)}
.event.revise .etype{color:var(--amber);border-color:var(--amber-d);background:var(--amber-dim)}
.event.pub .etype{color:var(--steel);border-color:var(--steel-d);background:var(--steel-dim)}
.event.asset .etype{color:var(--ink-2)}
.event.decide .etype{color:var(--red);border-color:var(--red-d);background:var(--red-dim)}
.event .ebody{flex:1;min-width:0}
.event .et{font-size:13.5px;color:var(--ink);font-weight:500}
.event .es{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:2px}
.event .ets{font-family:var(--mono);font-size:10.5px;color:var(--ink-4);white-space:nowrap}

/* =================================================================
   GENERIC SCREEN BUILDING BLOCKS (library, canon, etc.)
   ================================================================= */
.subnav{display:flex;gap:4px;border-bottom:1px solid var(--line-2);margin-bottom:18px}
.subnav button{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--ink-3);background:none;
  border:none;border-bottom:2px solid transparent;padding:9px 13px;cursor:pointer;margin-bottom:-1px}
.subnav button:hover{color:var(--ink)}
.subnav button.on{color:var(--ink);border-bottom-color:var(--amber)}

.fpanel{display:flex;flex-direction:column;gap:6px}
.fpanel .fh{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-4);
  margin:14px 2px 4px}
.fpanel .fopt{display:flex;align-items:center;gap:9px;padding:6px 8px;border-radius:4px;font-size:13px;
  color:var(--ink-2);cursor:pointer}
.fpanel .fopt:hover{background:var(--s2);color:var(--ink)}
.fpanel .fopt .box{width:14px;height:14px;border:1px solid var(--line-3);border-radius:3px;flex:0 0 auto}
.fpanel .fopt.on .box{background:var(--steel);border-color:var(--steel);box-shadow:0 0 8px rgba(110,166,216,.5)}

/* doc cards (library grid) */
.doc{cursor:pointer;overflow:hidden;transition:.18s var(--ease);display:flex;flex-direction:column}
.doc:hover{border-color:var(--line-3);transform:translateY(-2px);box-shadow:var(--shadow)}
.doc .thumb{height:120px;position:relative;border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,var(--s3),var(--s1));display:grid;place-items:center;overflow:hidden}
.doc .thumb::after{content:"";position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(135deg,transparent 0 11px,rgba(126,151,188,.05) 11px 12px)}
.doc .thumb .ty{font-family:var(--mono);font-size:13px;letter-spacing:.18em;color:var(--steel);
  border:1px solid var(--line-2);border-radius:3px;padding:6px 12px;background:rgba(8,12,19,.6);z-index:1}
.doc .db{padding:13px 15px;display:flex;flex-direction:column;gap:7px}
.doc h4{margin:0;font-size:14px;font-weight:600}
.doc .dk{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);letter-spacing:.04em}

/* data table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-4);
  text-align:left;padding:11px 14px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--s1)}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.tbl tr{transition:.12s}
.tbl tbody tr:hover td{background:var(--s2);color:var(--ink)}
.tbl td .nm{color:var(--ink);font-weight:500}

/* meters */
.meter{height:7px;border-radius:4px;background:#16202f;overflow:hidden;border:1px solid var(--line)}
.meter i{display:block;height:100%;background:var(--steel);box-shadow:0 0 10px rgba(110,166,216,.45)}
.meter.amber i{background:var(--amber);box-shadow:0 0 10px rgba(224,166,72,.45)}
.meter.green i{background:var(--green);box-shadow:0 0 10px rgba(92,174,126,.45)}
.meter.red i{background:var(--red)}

/* split working layouts (doc detail) */
.worktri{display:grid;grid-template-columns:230px 1fr 320px;gap:1px;background:var(--line-2);
  border:1px solid var(--line-2);border-radius:6px;overflow:hidden;min-height:560px}
.worktri>div{background:var(--s1);padding:16px}
.metaline{display:flex;justify-content:space-between;gap:10px;font-size:12.5px;padding:7px 0;border-bottom:1px solid var(--line)}
.metaline .k{color:var(--ink-3)}
.editor-line{height:11px;border-radius:3px;background:var(--s4);margin:9px 0}
.editor-line.h{background:var(--ink-4);width:46%;height:14px;margin-top:18px}
.warnbar{display:flex;align-items:center;gap:11px;padding:11px 18px;background:var(--amber-dim);
  border-bottom:1px solid var(--amber-d);font-size:13px;color:var(--amber)}
.warnbar b{color:#f1c878}

/* diff (revision queue) */
.diffcol{padding:16px}
.diffline{height:11px;border-radius:3px;background:var(--s4);margin:8px 0}
.diffline.add{background:rgba(92,174,126,.28);border-left:2px solid var(--green)}
.diffline.del{background:rgba(210,107,79,.22);border-left:2px solid var(--red)}

/* real line diff (canon approval review panel) */
.diffwrap{border:1px solid var(--line-2);border-radius:6px;overflow:hidden;background:var(--s0)}
.diffhead{display:grid;grid-template-columns:1fr 1fr;font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;
  color:var(--ink-3);background:var(--s1);border-bottom:1px solid var(--line-2)}
.diffhead>span{padding:7px 12px}
.diffhead>span:last-child{border-left:1px solid var(--line-2);text-align:right}
.diffbody{max-height:430px;overflow:auto;font-family:var(--mono);font-size:11.5px;line-height:1.55}
.drow{display:grid;grid-template-columns:1fr 1fr}
.dcell{padding:1px 11px;white-space:pre-wrap;word-break:break-word;color:var(--ink-2);border-bottom:1px solid rgba(126,151,188,.045);min-height:18px}
.dcell:first-child{border-right:1px solid var(--line-2)}
.dcell.empty{background:repeating-linear-gradient(135deg,transparent,transparent 7px,rgba(126,151,188,.05) 7px,rgba(126,151,188,.05) 14px)}
.dcell.del{background:rgba(210,107,79,.14);color:var(--ink)}
.dcell.add{background:rgba(92,174,126,.14);color:var(--ink)}
.dcell.chg{background:rgba(224,166,72,.13);color:var(--ink)}
.dcell .mk{display:inline-block;width:11px;color:var(--ink-4);user-select:none}
.dcell.del .mk{color:var(--red)} .dcell.add .mk{color:var(--green)} .dcell.chg .mk{color:var(--amber)}
.dchip{display:inline-block;width:10px;height:10px;border-radius:2px;vertical-align:-1px;margin-right:4px}
.dchip.add{background:rgba(92,174,126,.55)} .dchip.del{background:rgba(210,107,79,.55)} .dchip.chg{background:rgba(224,166,72,.55)}
.rev-note{width:100%;box-sizing:border-box;resize:vertical;background:var(--s0);border:1px solid var(--line-2);border-radius:5px;
  color:var(--ink);font-family:var(--sans);font-size:13px;line-height:1.5;padding:9px 11px}
.rev-note:focus{outline:none;border-color:var(--steel-d)}
.rev-note::placeholder{color:var(--ink-4)}
.event.reject .etype{color:var(--red);border-color:var(--red-d);background:var(--red-dim)}

/* bars chart (financials) */
.bars{display:flex;align-items:flex-end;gap:14px;height:170px;padding-top:10px}
.bars .b{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}
.bars .b .col-b{width:100%;background:linear-gradient(180deg,var(--steel),var(--steel-d));border-radius:3px 3px 0 0;
  border:1px solid var(--steel-d);border-bottom:none;position:relative}
.bars .b.hot .col-b{background:linear-gradient(180deg,var(--amber),var(--amber-d));border-color:var(--amber-d)}
.bars .b .bv{font-family:var(--mono);font-size:11px;color:var(--ink-2)}
.bars .b .bl{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-4);text-transform:uppercase}

/* asset viewer */
.amedia{aspect-ratio:16/10;border:1px solid var(--line-2);border-radius:5px;position:relative;cursor:pointer;
  background:linear-gradient(135deg,var(--s3),var(--s0));display:grid;place-items:center;overflow:hidden;transition:.18s}
.amedia:hover{border-color:var(--line-3);transform:translateY(-2px)}
.amedia::after{content:"";position:absolute;inset:0;opacity:.4;
  background:repeating-linear-gradient(135deg,transparent 0 13px,rgba(126,151,188,.05) 13px 14px)}
.amedia .pl{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-3);z-index:1;text-align:center}
.amedia .play{position:absolute;z-index:1;width:40px;height:40px;border-radius:50%;border:1px solid var(--steel);
  display:grid;place-items:center;color:var(--steel);background:rgba(8,12,19,.6)}

/* mini graph for relationship side panels */
.minigraph{height:200px;position:relative;border:1px solid var(--line-2);border-radius:5px;overflow:hidden;
  background:radial-gradient(120% 120% at 50% 45%,#0c1422,#070b12 72%)}

/* =================================================================
   COMMAND PALETTE (⌘K)
   ================================================================= */
.palette{position:fixed;inset:0;z-index:100;display:none;align-items:flex-start;justify-content:center;
  padding-top:14vh;background:rgba(4,7,11,.6);backdrop-filter:blur(3px)}
.palette.on{display:flex;animation:rise .2s var(--ease)}
.pal-box{width:min(560px,92vw);background:var(--s1);border:1px solid var(--line-3);border-radius:8px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,.9);overflow:hidden}
.pal-in{display:flex;align-items:center;gap:11px;padding:15px 18px;border-bottom:1px solid var(--line-2)}
.pal-in input{flex:1;background:none;border:none;outline:none;color:var(--ink);font-family:var(--sans);font-size:16px}
.pal-in input::placeholder{color:var(--ink-4)}
.pal-in .esc{font-family:var(--mono);font-size:10px;color:var(--ink-4);border:1px solid var(--line-2);border-radius:3px;padding:2px 6px}
.pal-list{max-height:46vh;overflow-y:auto;padding:8px}
.pal-it{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:5px;cursor:pointer;color:var(--ink-2)}
.pal-it .pn{font-family:var(--mono);font-size:10px;color:var(--ink-4);width:22px}
.pal-it .pic{width:16px;height:16px;stroke:currentColor;fill:none;opacity:.8}
.pal-it .pgrow{flex:1}
.pal-it .pmeta{font-family:var(--mono);font-size:10px;color:var(--ink-4)}
.pal-it.sel,.pal-it:hover{background:var(--steel-dim);color:#fff}
.pal-it.sel .pic{color:var(--steel)}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:1280px){
  .hero-readouts{grid-template-columns:repeat(2,1fr)}
  .counts{grid-template-columns:repeat(5,1fr)}
  .inspector{display:none}
}
@media(max-width:1080px){
  .app{grid-template-columns:64px 1fr}
  .brand .bt,.brand .bs,.item .lbl,.item .ct,.nav .group,.rail-foot{display:none}
  .brand{justify-content:center;padding:14px 0}
  .item{justify-content:center;padding:10px}
  .counts{grid-template-columns:repeat(3,1fr)}
  .rm-detail{grid-template-columns:1fr}
  .worktri{grid-template-columns:1fr}
}
@media(max-width:760px){
  .g2,.g3,.g4,.g5,.g6{grid-template-columns:1fr 1fr}
  .hero-top{flex-direction:column}.hero-seal{display:none}
  .counts{grid-template-columns:1fr 1fr}
  .cmd{display:none}
  .tb-right .chip{display:none}
  .crumb .s{display:none}
  .classbar{white-space:nowrap;overflow:hidden}
  .classbar span:not(.mid):not(.edge){display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;scroll-behavior:auto !important}
}

/* =================================================================
   AUTH GATE / LOGIN — shown until an authenticated session exists
   ================================================================= */
.gate{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 100% at 50% 0%,#0c1422,#06090f 72%)}
.gate::before{content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:linear-gradient(var(--line) 1px,transparent 1px) 0 0/46px 46px,linear-gradient(90deg,var(--line) 1px,transparent 1px) 0 0/46px 46px;
  -webkit-mask-image:radial-gradient(68% 60% at 50% 34%,#000,transparent 80%);mask-image:radial-gradient(68% 60% at 50% 34%,#000,transparent 80%)}
.gate-inner{position:relative;width:min(412px,94vw);text-align:center}
.gate-class{display:flex;align-items:center;gap:12px;justify-content:center;font-family:var(--mono);font-size:9.5px;
  letter-spacing:.2em;color:var(--amber);margin-bottom:32px}
.gate-class .edge{height:8px;flex:1;max-width:56px;background:repeating-linear-gradient(135deg,rgba(224,166,72,.5) 0 5px,transparent 5px 10px)}
.gate-seal{width:90px;height:90px;margin:0 auto 18px;position:relative;display:grid;place-items:center}
.gate-seal img{width:58px;height:58px;filter:drop-shadow(0 0 14px rgba(110,166,216,.55))}
.gate-seal .ring{position:absolute;inset:0;border:1px solid var(--line-3);border-radius:50%}
.gate-seal .ring.r2{inset:12px;border-style:dashed;border-color:rgba(110,166,216,.3);animation:spin 60s linear infinite}
.gate-title{font-weight:800;font-size:33px;letter-spacing:.15em;margin:0}
.gate-tagline{font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--steel);margin-top:9px}
.gate-loading{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);
  margin-top:34px;animation:gpulse 1.6s ease-in-out infinite}
@keyframes gpulse{0%,100%{opacity:.45}50%{opacity:1}}
.gate-form{margin-top:30px;text-align:left}
.gate-field{margin-bottom:14px}
.gate-field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.gate-field input{width:100%;background:var(--s1);border:1px solid var(--line-2);border-radius:var(--radius);color:var(--ink);
  font-family:var(--mono);font-size:14px;padding:11px 13px;outline:none;transition:.15s var(--ease)}
.gate-field input:focus{border-color:var(--steel);box-shadow:0 0 0 3px rgba(110,166,216,.15);background:var(--s2)}
.gate-err{min-height:15px;font-family:var(--mono);font-size:11px;color:var(--red);margin:0 0 10px;letter-spacing:.03em}
.gate-btn{width:100%;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:#06121f;background:var(--steel);border:1px solid var(--steel);border-radius:var(--radius);padding:12px;cursor:pointer;transition:.15s var(--ease)}
.gate-btn:hover{background:#86b8e2}
.gate-btn:disabled{opacity:.55;cursor:default}
.gate-error{font-family:var(--mono);font-size:12px;color:var(--red);margin-top:26px;line-height:1.5}
.gate-foot{margin-top:36px;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-4)}
.gate-foot span{display:block;margin-top:7px;letter-spacing:.06em;text-transform:none;opacity:.7}

/* ============ MARKDOWN IMPORT (modal + dropzone + preview + toast) ============ */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:24px;
  background:rgba(4,8,14,.72);backdrop-filter:blur(3px)}
.modal.on{display:flex;animation:rise .2s var(--ease)}
.modal-box{width:min(620px,94vw);max-height:88vh;display:flex;flex-direction:column;background:var(--s1);
  border:1px solid var(--line-3);border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6);overflow:hidden}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line-2)}
.mh-t{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;color:var(--ink)}
.mh-t svg{color:var(--steel)}
.modal-head .esc{font-family:var(--mono);font-size:10px;color:var(--ink-4);border:1px solid var(--line-2);border-radius:3px;padding:2px 6px;cursor:pointer}
.modal-head .esc:hover{color:var(--ink-2);border-color:var(--line-3)}
.modal-body{padding:18px;overflow-y:auto}
.modal-foot{display:flex;align-items:center;gap:10px;padding:13px 18px;border-top:1px solid var(--line-2);background:var(--s0)}
.modal-foot .grow{flex:1}

.dropzone{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;cursor:pointer;
  padding:26px 18px;border:1.5px dashed var(--line-3);border-radius:6px;background:var(--s0);transition:.15s var(--ease)}
.dropzone:hover,.dropzone.over{border-color:var(--steel);background:var(--steel-dim)}
.dz-ic{font-size:26px;color:var(--steel);line-height:1}
.dz-t{font-size:13.5px;color:var(--ink-2)}
.dz-t b{color:var(--ink)}
.dz-link{color:var(--steel);text-decoration:underline;text-underline-offset:2px}
.dz-s{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-4);max-width:440px}

.imp-list{display:flex;flex-direction:column;gap:8px;margin-top:14px}
.imp-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--line-2);border-radius:5px;background:var(--s2)}
.ir-ic{flex:none;width:34px;height:34px;display:grid;place-items:center;border-radius:4px;background:var(--steel-dim);
  color:var(--steel);font-family:var(--mono);font-size:11px;letter-spacing:.04em}
.ir-main{flex:1;min-width:0}
.ir-t{font-size:13.5px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ir-s{font-family:var(--mono);font-size:11px;color:var(--ink-3);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ir-note{font-family:var(--mono);font-size:10.5px;color:var(--amber);margin-top:3px}
.ir-target{flex:none}
.imp-msg{min-height:16px;margin-top:12px;font-family:var(--mono);font-size:11.5px;letter-spacing:.03em;color:var(--ink-3)}
.imp-msg.err{color:var(--red)}
.imp-msg.success{color:var(--green)}

/* asset upload modal — metadata form + per-file progress */
.up-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0 2px}
.up-field{display:flex;flex-direction:column;gap:4px;min-width:0}
.up-field.up-wide{grid-column:1 / -1}
.up-field label{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.up-field .up-hint{text-transform:none;letter-spacing:.02em;color:var(--ink-4)}
.up-field input,.up-field select,.up-field textarea{width:100%;padding:7px 9px;border:1px solid var(--line-2);border-radius:5px;
  background:var(--s0);color:var(--ink);font-family:inherit;font-size:13px;resize:vertical}
.up-field input:focus,.up-field select:focus,.up-field textarea:focus{outline:none;border-color:var(--steel)}
.up-bar{height:4px;border-radius:3px;background:var(--line-2);overflow:hidden;margin-top:6px}
.up-bar i{display:block;height:100%;width:0;background:var(--steel);transition:width .2s var(--ease)}

.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);z-index:400;display:flex;align-items:center;gap:9px;
  padding:11px 16px;background:var(--s2);border:1px solid var(--line-3);border-radius:6px;box-shadow:0 16px 40px rgba(0,0,0,.5);
  font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:var(--ink);opacity:0;pointer-events:none;transition:.25s var(--ease)}
.toast.on{opacity:1;transform:translate(-50%,0)}

/* document detail — real markdown panes (used when a body is present) */
.dpane{min-width:0}
.md-src{margin:0;max-height:420px;overflow:auto;white-space:pre-wrap;word-break:break-word;
  font-family:var(--mono);font-size:11.5px;line-height:1.55;color:var(--ink-2)}
.md-body{max-height:440px;overflow:auto;font-size:13.5px;line-height:1.62;color:var(--ink-2)}
.md-body h1,.md-body h2,.md-body h3,.md-body h4{color:var(--ink);font-weight:600;line-height:1.3;margin:16px 0 8px}
.md-body h1{font-size:19px}.md-body h2{font-size:16px}.md-body h3{font-size:14.5px}.md-body h4{font-size:13px}
.md-body h1:first-child,.md-body h2:first-child{margin-top:0}
.md-body p{margin:0 0 10px}
.md-body ul,.md-body ol{margin:0 0 10px;padding-left:20px}
.md-body li{margin:3px 0}
.md-body code{font-family:var(--mono);font-size:.88em;background:var(--s3);border-radius:3px;padding:1px 5px;color:var(--steel)}
.md-body pre.md-code{background:var(--s0);border:1px solid var(--line-2);border-radius:5px;padding:11px 13px;overflow:auto;margin:0 0 12px}
.md-body pre.md-code code{background:none;padding:0;color:var(--ink-2)}
.md-body blockquote{margin:0 0 12px;padding:4px 14px;border-left:3px solid var(--line-3);color:var(--ink-3)}
.md-body a{color:var(--steel);text-underline-offset:2px}
.md-body hr{border:none;border-top:1px solid var(--line-2);margin:16px 0}
.md-body strong{color:var(--ink)}

/* ===================================================================
   v0.5 — in-app Markdown editor (Document Detail "edit mode")
   =================================================================== */
.grow{flex:1}
/* clickable status-tag links (proposed-revision → Revision Queue) */
button.dlink{font-family:var(--mono);background:none;text-align:left;transition:.15s var(--ease)}
button.dlink:hover{filter:brightness(1.18);border-color:var(--amber)}

.ed-bar{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--line-2);background:var(--s0)}
.ed-tools{display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.ed-tool{font-family:var(--mono);font-size:11px;min-width:30px;height:26px;padding:0 8px;color:var(--ink-2);
  background:var(--s2);border:1px solid var(--line-2);border-radius:4px;cursor:pointer;transition:.15s var(--ease)}
.ed-tool:hover{color:#fff;border-color:var(--line-3);background:var(--s3)}
.ed-tool b,.ed-tool i{font-style:normal;font-weight:700}
.ed-tool i{font-style:italic;font-weight:500}
.ed-sep{width:1px;height:18px;background:var(--line-2);margin:0 4px}
.ed-safe{font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--green);border:1px solid var(--green-d);
  border-radius:3px;padding:1px 5px;margin-left:6px;vertical-align:1px}

.ed-split{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2)}
.ed-pane{background:var(--s1);padding:14px 16px;min-width:0}
.ed-pane:last-child{background:var(--s0)}
.ed-pane-h{margin-bottom:10px}
.ed-textarea{width:100%;height:clamp(320px,52vh,560px);box-sizing:border-box;resize:vertical;
  background:var(--s0);border:1px solid var(--line-2);border-radius:5px;padding:12px 13px;
  font-family:var(--mono);font-size:12.5px;line-height:1.62;color:var(--ink);tab-size:2}
.ed-textarea:focus{outline:none;border-color:var(--steel-d);box-shadow:0 0 0 1px var(--steel-dim)}
.ed-textarea::placeholder{color:var(--ink-4)}
.ed-preview{height:clamp(320px,52vh,560px);max-height:none;border:1px solid var(--line-2);border-radius:5px;
  padding:12px 14px;background:var(--s1)}

.ed-foot{padding:13px 16px;border-top:1px solid var(--line-2);background:var(--s1);display:flex;flex-direction:column;gap:11px}
.ed-foot-row{display:flex;align-items:center;gap:11px}
.ed-foot-row label{flex:0 0 auto}
.ed-summary{flex:1;background:var(--s0);border:1px solid var(--line-2);border-radius:5px;padding:8px 11px;
  font-family:var(--sans);font-size:13px;color:var(--ink)}
.ed-summary:focus{outline:none;border-color:var(--steel-d)}
.ed-summary::placeholder{color:var(--ink-4)}
.ed-diffbar{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11.5px}
.ddelta{font-weight:600}
.ddelta.add{color:var(--green)} .ddelta.del{color:var(--red)} .ddelta.chg{color:var(--amber)}
.ed-difffull{margin-top:2px}

@media(max-width:900px){ .ed-split{grid-template-columns:1fr} .ed-textarea,.ed-preview{height:auto;min-height:260px} }

/* ===================================================================
   v1.1 — Integrated Authoring Workspace (editor sidebar + inline refs)
   =================================================================== */
/* inline `[[ID]]` reference chips (preview + Document Detail) */
.md-body .mdref{display:inline-flex;align-items:baseline;gap:4px;padding:0 5px;border-radius:3px;
  background:var(--steel-dim);border:1px solid var(--steel-d);color:var(--steel);text-decoration:none;
  font-size:.93em;line-height:1.5;white-space:nowrap;vertical-align:baseline;transition:.15s var(--ease)}
.md-body a.mdref{cursor:pointer}
.md-body a.mdref:hover{filter:brightness(1.2);border-color:var(--steel)}
.md-body .mdref-ty{font-family:var(--mono);font-size:8px;letter-spacing:.06em;text-transform:uppercase;opacity:.7}
.md-body .mdref-t{overflow:hidden;text-overflow:ellipsis;max-width:230px}
.md-body .mdref.unresolved{background:var(--amber-dim);border-color:var(--amber-d);color:var(--amber)}

/* editor metadata strip (in the toolbar) */
.ed-metastrip{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--ink-3)}
.ed-metastrip .ems-id{color:var(--ink-2);font-size:10.5px}
.ed-metastrip .ems-v,.ed-metastrip .ems-dom{color:var(--ink-3);font-size:11px}
#ed-aside-toggle.on{color:#fff;border-color:var(--steel-d);background:var(--steel-dim)}
@media(max-width:1180px){ .ed-metastrip .ems-dom{display:none} }

/* 3-pane authoring layout: source | preview | author sidebar */
.ed-work{display:flex;gap:1px;background:var(--line-2)}
.ed-work>.ed-split{flex:1 1 auto;min-width:0}
.ed-aside{flex:0 0 322px;min-width:0;background:var(--s1);display:flex;flex-direction:column}
.ed-work.aside-collapsed>.ed-aside{display:none}

.ed-aside-tabs{display:flex;gap:2px;padding:8px 7px 0;background:var(--s0);border-bottom:1px solid var(--line-2)}
.ed-aside-tab{flex:1;font-family:var(--mono);font-size:9.5px;letter-spacing:.02em;padding:8px 3px;color:var(--ink-3);
  background:none;border:1px solid transparent;border-bottom:none;border-radius:4px 4px 0 0;cursor:pointer;transition:.15s var(--ease)}
.ed-aside-tab:hover{color:var(--ink-2)}
.ed-aside-tab.on{color:var(--ink);background:var(--s1);border-color:var(--line-2)}
.ed-aside-body{flex:1;min-height:0;overflow:auto;padding:12px}

.ed-aside-note{font-size:10.5px;line-height:1.55;color:var(--ink-3);margin-bottom:11px}
.ed-aside-note .mono{color:var(--steel)}
.ed-aside-empty{font-size:11.5px;line-height:1.6;color:var(--ink-4);padding:16px 6px;text-align:center}
.ed-aside-h{font-family:var(--mono);font-size:9px;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-4);margin:13px 0 7px}
.ed-aside-h:first-child{margin-top:0}

.ed-find{display:flex;gap:6px;margin-bottom:9px}
.ed-find-in{flex:1;min-width:0;background:var(--s0);border:1px solid var(--line-2);border-radius:5px;padding:7px 9px;
  font-family:var(--mono);font-size:11px;color:var(--ink)}
.ed-find-in:focus{outline:none;border-color:var(--steel-d)}
.ed-find-in::placeholder{color:var(--ink-4)}

/* a record row (Ask evidence · canon · ref search · in-doc refs) */
.ed-rec{display:flex;flex-direction:column;gap:5px;width:100%;text-align:left;padding:8px 9px;margin-bottom:6px;
  background:var(--s2);border:1px solid var(--line-2);border-left-width:2px;border-radius:5px}
.ed-rec.green{border-left-color:var(--green-d)} .ed-rec.red{border-left-color:var(--red-d)}
.ed-rec.steel{border-left-color:var(--steel-d)} .ed-rec.amber{border-left-color:var(--amber-d)}
.ed-rec.unresolved{border-left-color:var(--amber-d)}
.ed-rec-h{display:flex;align-items:center;gap:6px}
.ed-rec-ty{font-family:var(--mono);font-size:8px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line-2);border-radius:3px;padding:1px 4px;flex:0 0 auto}
.ed-rec-id{font-size:10px;color:var(--ink-2)}
.ed-rec-open{margin-left:auto;color:var(--ink-3);text-decoration:none;font-size:13px;line-height:1;padding:0 2px;cursor:pointer}
.ed-rec-open:hover{color:var(--steel)}
.ed-rec-t{font-size:12px;line-height:1.42;color:var(--ink);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ed-rec-why{font-family:var(--mono);font-size:9px;color:var(--ink-4)}
.ed-rec-foot{display:flex;gap:6px}
.ed-rec-ins{font-family:var(--mono);font-size:9.5px;color:var(--steel);border:1px solid var(--steel-d);border-radius:3px;
  padding:2px 8px;cursor:pointer;background:var(--steel-dim);transition:.15s var(--ease)}
.ed-rec-ins:hover{filter:brightness(1.2)}

/* Ask copilot summary */
.ed-ask-sum{display:flex;flex-direction:column;gap:7px;padding:9px 10px;margin-bottom:6px;background:var(--s2);
  border:1px solid var(--line-2);border-radius:5px}
.ed-ask-sum p{margin:0;font-size:12px;line-height:1.5;color:var(--ink-2)}

/* live knowledge-suggestion card */
.ed-scard{display:flex;flex-direction:column;gap:5px;width:100%;text-align:left;padding:8px 9px;margin-bottom:6px;
  background:var(--s2);border:1px solid var(--line-2);border-radius:5px;cursor:pointer;transition:.15s var(--ease)}
.ed-scard:hover{border-color:var(--line-3);background:var(--s3)}
.ed-scard-h{display:flex;align-items:center;gap:7px}
.ed-scard-loc{margin-left:auto;font-size:9px;color:var(--ink-4)}
.ed-scard-t{font-size:12px;line-height:1.42;color:var(--ink-2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

@media(max-width:1080px){ .ed-work{flex-direction:column} .ed-aside{flex:0 0 auto} .ed-aside-body{height:auto;max-height:380px} }

/* Document Detail — "References in document" panel */
.dref-list{display:flex;flex-direction:column;gap:4px}
.dref{display:flex;align-items:center;gap:8px;width:100%;text-align:left;padding:5px 8px;background:var(--s2);
  border:1px solid var(--line-2);border-radius:5px;cursor:pointer;transition:.15s var(--ease)}
button.dref:hover{border-color:var(--line-3);background:var(--s3)}
.dref-id{font-size:10px;color:var(--steel);flex:0 0 auto}
.dref-t{font-size:11.5px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dref.unresolved{cursor:default;border-style:dashed}
.dref.unresolved .dref-id{color:var(--amber)} .dref.unresolved .dref-t{color:var(--ink-4)}

/* ===================================================================
   v0.5 — Asset Intelligence (detail panel, badges, filters, linking)
   =================================================================== */
.asset-search{flex:0 1 280px;min-width:150px;background:var(--s0);border:1px solid var(--line-2);border-radius:5px;
  padding:7px 11px;font-family:var(--mono);font-size:11.5px;letter-spacing:.02em;color:var(--ink)}
.asset-search:focus{outline:none;border-color:var(--steel-d)}
.asset-search::placeholder{color:var(--ink-4)}
#asset-filters .btn.sm[data-af]{position:relative}
.af-ct{font-family:var(--mono);font-size:9px;opacity:.6;margin-left:5px}

/* badge overlay on asset cards + in the detail header */
.asset-badges{display:flex;flex-wrap:wrap;gap:5px}
.badge{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;
  text-transform:uppercase;padding:2px 6px;border-radius:3px;border:1px solid var(--line-2);color:var(--ink-3);background:rgba(8,12,19,.7)}
.badge.linked{color:var(--green);border-color:var(--green-d)}
.badge.suggested{color:var(--steel);border-color:var(--steel-d)}
.badge.canon{color:var(--amber);border-color:var(--amber-d)}
.badge.unlinked{color:var(--ink-3)}
.amedia .asset-badges{position:absolute;top:6px;left:6px;z-index:2}

.asset-detail .ad-preview{aspect-ratio:16/10;border:1px solid var(--line-2);border-radius:5px;overflow:hidden;
  position:relative;background:var(--s0);display:flex;align-items:center;justify-content:center}
.asset-detail .ad-preview img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ad-sec{margin-top:16px}
.ad-links{display:flex;flex-direction:column;gap:5px;margin-top:6px}
.ad-link{display:flex;align-items:center;gap:8px;padding:6px 9px;border:1px solid var(--line-2);border-radius:5px;
  background:var(--s2);cursor:pointer;transition:.15s var(--ease)}
.ad-link:hover{border-color:var(--line-3);background:var(--s3)}
.ad-link .ai-ty{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;
  padding:2px 5px;border-radius:3px;border:1px solid var(--line-2);color:var(--ink-3);flex:0 0 auto}
.ad-link .ai-t{flex:1;font-size:12.5px;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ad-link .ai-rs{font-family:var(--mono);font-size:9px;color:var(--ink-4);flex:0 0 auto}
.ad-link.green .ai-ty{color:var(--green);border-color:var(--green-d)}
.ad-link.steel .ai-ty{color:var(--steel);border-color:var(--steel-d)}
.ad-link.red .ai-ty{color:var(--red);border-color:var(--red-d)}
.ad-link.amber .ai-ty{color:var(--amber);border-color:var(--amber-d)}

.ad-linkbtns{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ad-picker{margin-top:8px;border:1px solid var(--steel-d);border-radius:6px;background:var(--s0);padding:10px}
.ad-picker input{width:100%;box-sizing:border-box;background:var(--s1);border:1px solid var(--line-2);border-radius:4px;
  padding:7px 10px;font-family:var(--mono);font-size:11.5px;color:var(--ink);margin-bottom:8px}
.ad-picker input:focus{outline:none;border-color:var(--steel-d)}
.ad-picklist{max-height:200px;overflow:auto;display:flex;flex-direction:column;gap:3px}
.ad-pick{padding:6px 9px;border-radius:4px;font-size:12.5px;color:var(--ink-2);cursor:pointer;border:1px solid transparent}
.ad-pick:hover{background:var(--s3);color:#fff;border-color:var(--line-2)}
.ad-pick .pk-id{font-family:var(--mono);font-size:10px;color:var(--ink-4);margin-right:7px}
.ad-placeholder{font-size:12px;color:var(--ink-4);border:1px dashed var(--line-2);border-radius:5px;padding:10px 12px;margin-top:6px}

/* =======================================================================
   v0.6 — KNOWLEDGE GRAPH · IMPACT · ASSET ANALYTICS · TIMELINE · SEARCH
   ======================================================================= */

/* ---- Relationship Explorer (#/graph/:id) ---- */
.relx{display:grid;grid-template-columns:1fr 268px;gap:14px;align-items:start}
.relx-main{display:flex;flex-direction:column;overflow:hidden}
.relx-bar{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line-2)}
.relx-crumb{display:flex;align-items:baseline;gap:8px;min-width:0}
.relx-crumb .dim{color:var(--ink-4)}
.relx-tools{display:flex;gap:6px}
.relx-stage{position:relative;height:560px;overflow:hidden;cursor:grab;
  background:radial-gradient(circle at 50% 44%,rgba(110,166,216,.06),transparent 62%),var(--s0)}
.relx-stage.panning{cursor:grabbing}
.relx-svg{width:100%;height:100%;display:block;touch-action:none;user-select:none}
.relx-svg.panning{cursor:grabbing}
.relx-empty{padding:48px 20px;text-align:center;color:var(--ink-3)}
.relx-legend{display:flex;align-items:center;gap:16px;padding:9px 14px;border-top:1px solid var(--line-2);
  font-family:var(--mono);font-size:10px;color:var(--ink-3)}
.relx-legend i{display:inline-block;width:16px;height:0;vertical-align:middle;margin-right:5px}
.relx-legend .lg-typed{border-top:2px solid var(--steel)}
.relx-legend .lg-derived{border-top:2px dashed var(--ink-4)}
.relx-side{position:sticky;top:8px}
/* svg edges + labels */
.rel-edge{fill:none;stroke:rgba(110,166,216,.5);stroke-width:1.5;transition:opacity .2s,stroke .2s,stroke-width .2s}
.rel-edge.derived{stroke:rgba(126,151,188,.3);stroke-dasharray:3 5;stroke-width:1.2}
.rel-edge.on{stroke:var(--steel);stroke-width:2.4;opacity:1}
.rel-edge.off{opacity:.1}
.rel-elabel{fill:var(--ink-3);font-family:var(--mono);font-size:10px;text-anchor:middle;
  paint-order:stroke;stroke:var(--s0);stroke-width:4px;stroke-linejoin:round;pointer-events:none}
.rel-elabel.off{opacity:.08}
/* svg nodes */
.rel-node{cursor:pointer}
.rel-node .rel-halo{fill:rgba(110,166,216,0);transition:fill .2s}
.rel-node .rel-disc{fill-opacity:.16;stroke-width:1.6;transition:stroke-width .2s,fill-opacity .2s}
.rel-node.root .rel-disc{fill-opacity:.26;stroke-width:2.6}
.rel-node .rel-glyph{text-anchor:middle;font-size:13px;fill:#fff;pointer-events:none}
.rel-node .rel-nlabel{text-anchor:middle;fill:var(--ink);font-size:12px;font-weight:500;pointer-events:none;
  paint-order:stroke;stroke:var(--s0);stroke-width:3px;stroke-linejoin:round}
.rel-node .rel-ntype{text-anchor:middle;fill:var(--ink-4);font-family:var(--mono);font-size:9px;pointer-events:none}
.rel-node:hover .rel-halo{fill:rgba(110,166,216,.12)}
.rel-node:hover .rel-disc{fill-opacity:.32}
.rel-node.sel .rel-halo{fill:rgba(110,166,216,.24)}
.rel-node.sel .rel-disc{stroke-width:2.8}
.rel-node.dim{opacity:.18}
/* explorer inspector (reuses the .ih/.iline look without the absolute overlay) */
#rel-inspector .ih{display:flex;align-items:center;gap:8px;margin-bottom:10px}
#rel-inspector .ih .d{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
#rel-inspector .ih b{font-size:14.5px;font-weight:600;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#rel-inspector .iline{display:flex;justify-content:space-between;gap:10px;font-family:var(--mono);font-size:11px;color:var(--ink-3);padding:5px 0;border-bottom:1px solid var(--line)}
#rel-inspector .iline .v{color:var(--ink);text-align:right}
#rel-inspector .idesc{font-size:12px;color:var(--ink-2);margin:10px 0 0;line-height:1.5}
#rel-inspector .ifoot{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}
.rel-groups{margin-top:12px;display:flex;flex-direction:column;gap:2px}
.rel-grp{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-3);padding:4px 0;border-bottom:1px solid var(--line)}
.rel-grp .rg-n{color:var(--ink)}
.rel-connect{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.rel-connect-row{display:flex;gap:6px}
.rel-rt{flex:1;background:var(--s1);border:1px solid var(--line-2);border-radius:4px;color:var(--ink);font-family:var(--mono);font-size:11px;padding:5px 7px}
.rel-rt:focus{outline:none;border-color:var(--steel-d)}
.rel-existing{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.rel-extag{display:inline-flex;align-items:center;gap:4px;font-family:var(--mono);font-size:10px;color:var(--steel);border:1px solid var(--steel-d);border-radius:4px;padding:2px 4px 2px 7px}
.rel-exdel{background:none;border:none;color:var(--ink-4);cursor:pointer;font-size:11px;padding:0 2px;line-height:1}
.rel-exdel:hover{color:var(--red)}

/* ---- Relationship Map (Document Detail) ---- */
.rmap{font-family:var(--sans)}
.rmap-root{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);font-size:13.5px;margin-bottom:8px}
.rmap-root .rmap-dot{width:9px;height:9px;border-radius:50%;background:var(--steel);box-shadow:0 0 8px var(--steel)}
.rmap-root .rmap-rootty{font-family:var(--mono);font-size:9px;color:var(--ink-4);text-transform:uppercase;letter-spacing:.08em;margin-left:auto}
.rmap-grp{padding:6px 0 6px 8px;border-left:1px solid var(--line-2);margin-left:4px}
.rmap-k{color:var(--ink-2);font-size:11px;font-family:var(--mono);letter-spacing:.04em;margin-bottom:7px;display:flex;align-items:center;gap:7px}
.rmap-k .rmap-branch{color:var(--ink-4)}
.rmap-k .rmap-n{color:var(--ink-4);background:var(--s2);border-radius:8px;padding:0 6px}
.rmap-items{display:flex;flex-wrap:wrap;gap:6px;padding-left:18px}
.rmap-node{display:inline-flex;align-items:center;gap:6px;background:var(--s2);border:1px solid var(--line-2);border-radius:5px;padding:5px 9px;cursor:pointer;color:var(--ink-2);font-size:12px}
.rmap-node:hover{border-color:var(--steel-d);background:var(--s3);color:#fff}
.rmap-node .rmap-id{font-family:var(--mono);font-size:9px;color:var(--ink-4)}
.rmap-node .rmap-typed{color:var(--steel);font-family:var(--mono);font-weight:600}
.rmap-node.green{border-color:var(--green-d)} .rmap-node.green .rmap-id{color:var(--green)}
.rmap-node.red{border-color:var(--red-d)} .rmap-node.steel{border-color:var(--steel-d)} .rmap-node.amber{border-color:var(--amber-d)}
.rmap-more{font-family:var(--mono);font-size:10px;color:var(--ink-4);align-self:center}
.rmap-empty{color:var(--ink-4);font-size:12px;padding:4px 0 0 18px}

/* ---- Canon Impact Analysis (Revision Queue) ---- */
.impact-card{border-color:var(--amber-d)}
.impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.impact-cell{background:var(--s1);border:1px solid var(--line-2);border-radius:6px;padding:13px 8px;text-align:center}
.impact-n{display:block;font-size:25px;font-weight:700;line-height:1}
.impact-l{display:block;font-family:var(--mono);font-size:9.5px;color:var(--ink-3);margin-top:7px;letter-spacing:.03em}
.impact-foot{margin-top:11px}
.impact-list{margin:6px 0;padding-left:18px;color:var(--ink-2);font-size:13px;line-height:1.7}
.impact-list b{color:var(--ink);font-family:var(--mono)}

/* ---- Asset Intelligence analytics + link rows ---- */
.ad-analytics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0 4px}
.ad-stat{background:var(--s1);border:1px solid var(--line-2);border-radius:5px;padding:10px 6px;text-align:center}
.ad-stat-n{display:block;font-size:19px;font-weight:700;line-height:1.05}
.ad-stat-l{display:block;font-family:var(--mono);font-size:8.5px;color:var(--ink-3);margin-top:5px;letter-spacing:.03em}
.ad-link-main{flex:1;display:flex;align-items:center;gap:8px;min-width:0;background:none;border:none;cursor:pointer;color:inherit;padding:0;text-align:left;font:inherit}
.ad-link.sug{flex-wrap:wrap}
.ad-unlink{flex:0 0 auto;background:none;border:none;color:var(--ink-4);cursor:pointer;font-size:12px;line-height:1;padding:3px 4px;border-radius:3px}
.ad-unlink:hover{color:var(--red);background:var(--red-dim)}
.ai-conf{flex:0 0 auto;font-family:var(--mono);font-size:10px;color:var(--steel)}
.ad-accept{flex:0 0 auto;padding:3px 8px}

/* ---- Intelligence Timeline (#/timeline) ---- */
.tl-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.tl-stat{background:var(--s2);border:1px solid var(--line);border-radius:6px;padding:13px 10px;text-align:center}
.tl-stat-n{display:block;font-size:22px;font-weight:700;line-height:1}
.tl-stat-l{display:block;font-family:var(--mono);font-size:9px;color:var(--ink-3);margin-top:6px;letter-spacing:.04em}
.tl-filters{flex-wrap:wrap;gap:8px;margin-bottom:16px}
.tl-group{margin-bottom:18px}
.tl-daymark{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.tl-day{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.tl-dayline{flex:1;height:1px;background:var(--line)}
.tl-daycount{font-family:var(--mono);font-size:10px;color:var(--ink-4)}
.tl-items{display:flex;flex-direction:column;gap:8px}
.tl-card{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--s2);border:1px solid var(--line);border-left:3px solid var(--steel);border-radius:5px;transition:background .15s}
.tl-card:hover{background:var(--s3)}
.tl-ic{width:30px;height:30px;flex:0 0 auto;border-radius:4px;display:grid;place-items:center;border:1px solid var(--line-2);background:var(--s1);color:var(--ink-2)}
.tl-ic svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.7}
.tl-card.approval .tl-ic{color:var(--green);border-color:var(--green-d);background:var(--green-dim)}
.tl-card.rejection .tl-ic{color:var(--red);border-color:var(--red-d);background:var(--red-dim)}
.tl-card.revision .tl-ic{color:var(--amber);border-color:var(--amber-d);background:var(--amber-dim)}
.tl-card.import .tl-ic{color:var(--steel);border-color:var(--steel-d);background:var(--steel-dim)}
.tl-card.relationship .tl-ic{color:var(--steel);border-color:var(--steel-d)}
.tl-card.link .tl-ic{color:var(--ink-2)}
.tl-body-txt{flex:1;min-width:0}
.tl-t{font-size:13.5px;color:var(--ink);font-weight:500}
.tl-s{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:2px}
.tl-ts{font-family:var(--mono);font-size:10.5px;color:var(--ink-4);white-space:nowrap}

/* ===================================================================
   ASK ARGOS — program intelligence retrieval (#/ask) (v0.8)
   =================================================================== */
.ask-hero{margin-bottom:18px}
.ask-kick{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.04em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.ask-bar{display:flex;align-items:center;gap:10px;background:var(--s2);border:1px solid var(--line);border-radius:8px;padding:10px 12px;transition:border-color .15s}
.ask-bar:focus-within{border-color:var(--steel-d)}
.ask-bar>svg{flex:0 0 auto}
.ask-input{flex:1;min-width:0;background:none;border:none;color:var(--ink);font-family:var(--sans);font-size:16px;outline:none}
.ask-input::placeholder{color:var(--ink-4)}
.ask-examples{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px}
.ask-ex{background:var(--s1);border:1px solid var(--line-2);border-radius:14px;color:var(--ink-2);font-family:var(--sans);font-size:12px;padding:5px 11px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}
.ask-ex:hover{border-color:var(--steel-d);color:#fff;background:var(--s3)}

.ask-answer{margin-bottom:18px}
.ask-summary{font-size:15.5px;line-height:1.62;color:var(--ink);margin:0}
.ask-conf{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:12px;padding-top:10px;border-top:1px solid var(--line)}
.ask-conf-r{font-family:var(--mono);font-size:11px;color:var(--ink-3)}

.ask-sec{margin-bottom:18px}
.ask-sec-h{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}
.ask-sec-h h3{margin:0;font-size:14px;font-weight:600;letter-spacing:.02em;color:var(--ink)}

.ask-ev-list{display:flex;flex-direction:column;gap:8px}
.ask-ev{display:flex;gap:12px;width:100%;text-align:left;background:var(--s2);border:1px solid var(--line);border-radius:6px;padding:12px 14px;cursor:pointer;color:inherit;font:inherit;transition:border-color .15s,background .15s}
.ask-ev:hover{border-color:var(--steel-d);background:var(--s3)}
.ask-ev-ic{flex:0 0 auto;width:30px;height:30px;border-radius:5px;display:grid;place-items:center;background:var(--s1);border:1px solid var(--line-2);color:var(--steel);font-size:15px}
.ask-ev-thumb{flex:0 0 auto;width:50px;height:38px;border-radius:4px;overflow:hidden;background:var(--s1);border:1px solid var(--line-2)}
.ask-ev-thumb img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .25s}
.ask-ev-main{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.ask-ev-head{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ask-ev-ty{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-3)}
.ask-ev-id{font-size:10.5px;color:var(--ink-4)}
.ask-ev-title{font-size:13.5px;color:var(--ink);font-weight:500;line-height:1.42}
.ask-ev-snip{font-size:12px;color:var(--ink-2);line-height:1.5}
.ask-ev-why{display:flex;flex-wrap:wrap;gap:5px;margin-top:3px}
.ask-why{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-3);background:var(--s1);border:1px solid var(--line-2);border-radius:3px;padding:1px 5px}
.ask-why.exact{color:var(--green);border-color:var(--green-d)}

.ask-related{display:flex;flex-wrap:wrap;gap:8px}
.ask-chip{display:inline-flex;align-items:center;gap:7px;background:var(--s2);border:1px solid var(--line-2);border-radius:5px;padding:6px 10px;cursor:pointer;color:var(--ink-2);font:inherit;font-size:12px;transition:border-color .15s,color .15s,background .15s}
.ask-chip:hover{border-color:var(--steel-d);color:#fff;background:var(--s3)}
.ask-chip-ic{color:var(--steel)}
.ask-chip-ty{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-4)}
.ask-chip-via{font-family:var(--mono);font-size:9px;color:var(--ink-4)}

.ask-cites{border:1px solid var(--line);border-radius:6px;overflow:hidden}
.ask-cite{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:10px 14px;background:var(--s2);font-size:12.5px;border-bottom:1px solid var(--line)}
.ask-cite:last-child{border-bottom:none}
.ask-cite-ty{font-family:var(--mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-3)}
.ask-cite-id{font-size:11px;color:var(--steel)}
.ask-cite-t{flex:1;min-width:160px;color:var(--ink)}
.ask-cite-s{display:flex;align-items:center;gap:8px;margin-left:auto}
.ask-cite-src{background:none;border:none;color:var(--steel);cursor:pointer;font:inherit;font-size:12px;padding:0}
.ask-cite-src:hover{color:#fff;text-decoration:underline}
.ask-cite-src.plain{color:var(--ink-3);cursor:default}

.ask-empty{text-align:center;padding:40px 24px;color:var(--ink-3)}
.ask-empty-ic{font-size:30px;color:var(--ink-4);margin-bottom:12px}
.ask-empty-t{font-size:15px;color:var(--ink-2);margin-bottom:8px}
.ask-empty-s{font-size:13px;color:var(--ink-3);max-width:560px;margin:0 auto;line-height:1.6}

/* ---- Global search palette: grouped results ---- */
.pal-grp{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);
  padding:11px 13px 4px;display:flex;justify-content:space-between;align-items:baseline}
.pal-grp-n{color:var(--ink-4)}
.pal-it .pmeta{white-space:nowrap}
.pal-ask{border-bottom:1px solid var(--line);margin-bottom:2px}
.pal-ask .pn{color:var(--steel)}
.pal-ask .pgrow{color:var(--ink);font-weight:500}
.pal-ask .pmeta{color:var(--steel)}

/* ---- responsive ---- */
@media (max-width:1180px){
  .relx{grid-template-columns:1fr} .relx-side{position:static}
  .tl-stats{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:720px){
  .impact-grid{grid-template-columns:repeat(2,1fr)} .tl-stats{grid-template-columns:repeat(2,1fr)}
}

/* ====================== KNOWLEDGE SUGGESTIONS (v0.9) ====================== */
.sug-intro{line-height:1.6;color:var(--ink-3);max-width:1000px}
.sug-intro b{color:var(--ink-2)}
#sug-status-filters .af-ct{margin-left:6px;font-family:var(--mono);font-size:10px;color:var(--ink-3)}

/* grouped list */
.sug-group{margin-bottom:14px}
.sug-group-h{display:flex;align-items:center;gap:8px;margin:0 2px 6px;padding-bottom:5px;border-bottom:1px solid var(--line-2)}
.sug-group-t{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2)}
.sug-group-n{font-family:var(--mono);font-size:10px;color:var(--ink-4);background:var(--s1);border:1px solid var(--line-2);border-radius:10px;padding:1px 7px}
.sug-card{display:flex;flex-direction:column;gap:7px;padding:10px 12px;margin-bottom:7px;background:var(--s1);
  border:1px solid var(--line-2);border-left:3px solid var(--steel);border-radius:5px;cursor:pointer;transition:background .12s,border-color .12s}
.sug-card:hover{background:var(--s3);border-color:var(--line-3)}
.sug-card.on{background:var(--s3);border-color:var(--line-3);box-shadow:inset 0 0 0 1px var(--line-3)}
.sug-card-t{font-size:13px;color:var(--ink);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sug-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* confidence chip */
.conf-chip{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;border-radius:3px;border:1px solid var(--line-2);color:var(--ink-3)}
.conf-chip.High{color:var(--green);border-color:var(--green-d);background:var(--green-dim)}
.conf-chip.Medium{color:var(--amber);border-color:var(--amber-d);background:var(--amber-dim)}
.conf-chip.Low{color:var(--ink-3)}

/* detail */
.sug-extract{margin:0;padding:10px 14px;border-left:3px solid var(--steel-d);background:var(--s0);border-radius:0 5px 5px 0;
  font-size:13.5px;line-height:1.6;color:var(--ink);white-space:pre-wrap;word-break:break-word}
.sug-whys{display:flex;flex-wrap:wrap;gap:5px}
.sug-why{font-family:var(--mono);font-size:10px;color:var(--ink-2);background:var(--s1);border:1px solid var(--line-2);border-radius:3px;padding:2px 7px}
.sug-why.score{color:var(--steel);border-color:var(--steel-d)}

/* accept form */
.sug-actions{margin-top:2px}
.sug-form{display:flex;flex-wrap:wrap;gap:10px}
.sug-field{display:flex;flex-direction:column;gap:4px;flex:1 1 150px}
.sug-field label{margin:0}
.sug-field select,.sug-field input,.sug-actions .rev-note{width:100%;background:var(--s0);border:1px solid var(--line-2);border-radius:5px;
  color:var(--ink);font:inherit;font-size:13px;padding:7px 9px}
.sug-field select:focus,.sug-field input:focus,.sug-actions .rev-note:focus{outline:none;border-color:var(--steel-d)}
.sug-actions .rev-note{resize:vertical;font-size:12.5px}
.sug-note-canon{margin-top:9px;line-height:1.55;color:var(--ink-3);border-top:1px dashed var(--line-2);padding-top:9px}
.sug-note-canon b{color:var(--amber)}

@media (max-width:960px){ .sug-grid{grid-template-columns:1fr !important} }

/* ===================================================================
   PROGRAM GOVERNANCE (v1.0) — Dashboard rollup cells + registry tables.
   No new visual language — reuses the War Room panels, tags, .cnt tiles.
   =================================================================== */
.gov-cells{display:flex;gap:22px;flex-wrap:wrap}
.gov-cell{min-width:54px}
.gov-cell-v{font-family:var(--mono);font-size:25px;line-height:1;font-weight:500}
.gov-cell-l{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);margin-top:5px}
/* financial registry records table */
.gov-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.gov-tbl th{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-4);text-align:left;padding:8px 10px;border-bottom:1px solid var(--line-2)}
.gov-tbl td{padding:9px 10px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.gov-tbl tbody tr{cursor:pointer}
.gov-tbl tbody tr:hover td{background:var(--s2);color:var(--ink)}
.gov-tbl td .nm{color:var(--ink);font-weight:500}
.gov-tbl .num{font-family:var(--mono);text-align:right;white-space:nowrap}
