/* ─────────────────────────────────────────────────────────────────────────
   UDF 2.0 — design system, dressed in the Arero7 brand suite (v3.0)
   "One intelligence layer. Four voices."  One night underneath them all.
     · UDF is the product   → steel-blue is the signal of the app chrome
     · LEAPED is the ontology→ its six primitives ARE the data palette
     · emerald is the shared connective tissue (success / grounding)
     · intelWeaver is the agent → cyan is the register of Talk
   Type: Instrument Serif (italic display) · DM Sans (UI) · Geist Mono (metadata).
   Variable names are kept stable — every view reads --l/e/a/p/ev/d, --tx, --brand…
   ───────────────────────────────────────────────────────────────────────── */
:root{
  /* ── the six LEAPED primitives (brand v3.0 — the data palette) ──────────── */
  --l:#fb7185;  --e:#38bdf8;  --a:#fbbf24;  --p:#818cf8;  --ev:#34d399;  --d:#d946ef;
  --l-s:rgba(251,113,133,.14); --e-s:rgba(56,189,248,.14); --a-s:rgba(251,191,36,.14);
  --p-s:rgba(129,140,248,.14); --ev-s:rgba(52,211,153,.14); --d-s:rgba(217,70,239,.14);

  /* ── shared night — the one surface all four brands stand on ────────────── */
  /* the platform's royal-blue field: the canvas is a lit #1d3a8a blue under the
     fine raster; chrome and cards stay dark navy so panels pop against it */
  --field:#1d3a8a; --field-hi:#234699; --field-lo:#16307a;
  --bg:#0a1326; --bg-1:#0e1a33; --bg-2:#13203d; --bg-3:#1c2b4d;
  --line:rgba(134,162,212,.30); --line-2:rgba(134,162,212,.14);
  --tx:#eef3fb; --tx-2:rgba(205,219,242,.66); --tx-3:rgba(148,168,206,.46);

  /* ── brand signals — never paint outside these lanes ────────────────────── */
  --signal:#34d399;                                  /* emerald — connects everything */
  --coral:#ff6a55; --coral-soft:#ff8878;             /* Arero7 house — used sparingly */
  --steel:#7aa8ff; --steel-soft:#9dbbff;             /* UDF product — the app's signal */
  --weaver:#22d3ee; --weaver-soft:#67e8f9; --weaver-deep:#0891b2; --weaver-glow:rgba(34,211,238,.16); /* intelWeaver agent */

  /* UDF is the product, so --brand resolves to steel for all chrome */
  --brand:#7aa8ff; --brand-2:#9dbbff;
  --ok:#34d399; --warn:#fbbf24; --bad:#fb7185;

  /* ── type ───────────────────────────────────────────────────────────────── */
  --font-display:'Instrument Serif',Georgia,'Times New Roman',serif;
  --font-body:'DM Sans',system-ui,-apple-system,sans-serif;
  --mono:'Geist Mono',ui-monospace,'SFMono-Regular',monospace;

  /* large surfaces stay soft; small controls go sharp — that contrast is the brand */
  --r:14px; --r-s:10px; --r-xs:4px;
  --shadow:0 26px 64px -28px rgba(0,0,0,.72);
  --sidebar:262px; --dock:344px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(circle at 16% -12%, rgba(96,165,250,.28), transparent 52%),
    radial-gradient(circle at 84% 0%, rgba(56,189,248,.18), transparent 50%),
    linear-gradient(160deg,var(--field-lo) 0%, var(--field) 55%, var(--field-hi) 100%);
  color:var(--tx); font-family:var(--font-body); font-size:14px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow:hidden;
}
::selection{background:rgba(122,168,255,.30)}

/* Editorial serif for the display moments; DM Sans for functional headings. */
h1,h2,.display{font-family:var(--font-display);font-weight:400;font-style:italic;
  letter-spacing:-.01em;line-height:1.06;color:var(--tx);text-wrap:balance}
h3,h4{font-family:var(--font-body);font-weight:600;letter-spacing:-.005em}
.mono{font-family:var(--mono)}
.serif{font-family:var(--font-display);font-style:italic}
a{color:var(--brand-2);text-decoration:none}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
input,textarea,select{font:inherit;color:var(--tx)}

::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:rgba(134,162,212,.24);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:rgba(134,162,212,.40);background-clip:padding-box}

/* The brand's signature: a mono, wide-tracked, uppercase eyebrow in emerald. */
.eyebrow{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.22em;
  text-transform:uppercase;color:var(--signal);display:inline-flex;align-items:center;gap:8px}
.eyebrow.steel{color:var(--steel)} .eyebrow.weaver{color:var(--weaver)}
.eyebrow.coral{color:var(--coral)} .eyebrow.muted{color:var(--tx-3)}

/* ── App shell ─────────────────────────────────────────────────────────────── */
.app{display:grid;grid-template-columns:var(--sidebar) 1fr;height:100vh}
.sidebar{background:linear-gradient(180deg,var(--bg-1),var(--bg));border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:20px 14px;gap:6px;min-height:0}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 18px}
.brand-mark{width:38px;height:38px;flex-shrink:0;display:grid;place-items:center}
.brand-mark svg{width:100%;height:100%;display:block;filter:drop-shadow(0 4px 12px rgba(122,168,255,.18))}
.brand-name{font-family:var(--font-body);font-weight:700;font-size:19px;letter-spacing:.04em;line-height:1}
.brand-name b{color:var(--steel);font-weight:700}
.brand-sub{font-family:var(--mono);font-size:9px;color:var(--tx-3);letter-spacing:.2em;
  text-transform:uppercase;margin-top:5px}

.ent-switch{margin:2px 4px 14px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-s);
  background:var(--bg-2);display:flex;align-items:center;gap:10px;cursor:pointer;transition:.15s}
.ent-switch:hover{border-color:rgba(122,168,255,.35);background:var(--bg-3)}
.ent-switch .dot{width:7px;height:7px;border-radius:50%;background:var(--signal);box-shadow:0 0 9px var(--signal);flex-shrink:0}
.ent-switch .nm{font-weight:600;font-size:13px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ent-switch .ch{color:var(--tx-3);font-size:11px}

.nav{display:flex;flex-direction:column;gap:2px;overflow-y:auto;min-height:0;flex:1}
.nav-item{display:flex;align-items:center;gap:12px;padding:9px 11px;border-radius:var(--r-s);
  color:var(--tx-2);font-family:var(--font-body);font-weight:500;font-size:13.5px;
  transition:.13s;border:1px solid transparent;cursor:pointer}
.nav-item:hover{background:var(--bg-2);color:var(--tx)}
.nav-item.on{background:rgba(122,168,255,.10);color:var(--tx);border-color:rgba(122,168,255,.32);box-shadow:inset 2px 0 0 var(--steel)}
.nav-item .ic{width:20px;text-align:center;font-size:15px;flex-shrink:0}
.nav-item.on .ic{filter:drop-shadow(0 0 7px currentColor)}
.nav-foot{border-top:1px solid var(--line-2);padding-top:12px;margin-top:6px;font-size:11px;color:var(--tx-3)}
.nav-foot .who{display:flex;align-items:center;gap:8px;padding:6px 8px}
.nav-foot .av{width:27px;height:27px;border-radius:8px;background:var(--bg-3);border:1px solid var(--line);
  display:grid;place-items:center;font-weight:700;color:var(--steel);font-size:12px}
.nav-foot .mono{letter-spacing:.12em;text-transform:uppercase;font-size:9px}

/* The workspace reads as the platform surface: the royal-blue field under the
   same fine 3px dot-raster as the entrance gate, with a lit glow up top.
   Dark cards (bg-1) pop against it; the topbar's blur keeps the chrome dark. */
.main{min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden;
  background:
    radial-gradient(rgba(180,200,240,.09) 1px, transparent 1px) 0 0 / 3px 3px,
    radial-gradient(circle at 84% -16%, rgba(96,165,250,.24), transparent 55%),
    linear-gradient(160deg,var(--field-lo) 0%, var(--field) 55%, var(--field-hi) 100%)}
.topbar{height:62px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;
  padding:0 28px;flex-shrink:0;background:rgba(10,19,38,.62);backdrop-filter:blur(10px)}
.topbar h1{font-family:var(--font-display);font-style:italic;font-weight:400;font-size:21px;letter-spacing:-.01em}
.topbar .crumb{font-family:var(--mono);color:var(--tx-3);font-size:10px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase}
.topbar .sp{flex:1}
.view{flex:1;overflow-y:auto;padding:30px 28px}
.view-wrap{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:22px}

/* ── Cards / surfaces ──────────────────────────────────────────────────────── */
.card{background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.008)),var(--bg-1);
  border:1px solid var(--line);border-radius:var(--r);padding:22px}
.card.pad-0{padding:0;overflow:hidden}
.card-h{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.card-h h3{font-family:var(--font-body);font-size:15px;font-weight:600;letter-spacing:-.005em}
.card-h .sp{flex:1}
.card-sub{color:var(--tx-3);font-size:12.5px;margin-top:-10px;margin-bottom:14px;max-width:64ch}
.grid{display:grid;gap:16px}
.g-2{grid-template-columns:repeat(2,1fr)} .g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)} .g-6{grid-template-columns:repeat(6,1fr)}
@media(max-width:1080px){.g-4,.g-6{grid-template-columns:repeat(3,1fr)}.g-3{grid-template-columns:repeat(2,1fr)}}

/* ── Primitive stat (the six corners of reality) ───────────────────────────── */
.pstat{position:relative;border:1px solid var(--line);border-radius:var(--r);padding:16px 16px 14px;
  background:linear-gradient(180deg,rgba(255,255,255,.022),rgba(255,255,255,.004)),var(--bg-1);
  overflow:hidden;transition:.18s}
.pstat:hover{transform:translateY(-2px);border-color:var(--ac,var(--line));
  box-shadow:0 16px 40px -28px var(--ac,transparent)}
.pstat .bar{position:absolute;top:0;left:0;right:0;height:2px;background:var(--ac,var(--brand))}
.pstat .ic{font-size:19px;opacity:.92}
.pstat .v{font-family:var(--mono);font-size:29px;font-weight:600;margin-top:9px;line-height:1;
  letter-spacing:-.02em;color:var(--ac,var(--tx))}
.pstat .k{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--tx-3);margin-top:8px}
.pstat .sub{font-size:11px;color:var(--tx-2);margin-top:3px}

.stat{border:1px solid var(--line);border-radius:var(--r-s);padding:14px 16px;background:var(--bg-2)}
.stat .v{font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:-.02em}
.stat .k{font-family:var(--mono);font-size:10px;color:var(--tx-3);text-transform:uppercase;letter-spacing:.14em;margin-top:5px}

/* ── Badges / pills / chips ────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10px;font-weight:500;
  letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:999px;
  border:1px solid var(--line);background:var(--bg-3);color:var(--tx-2)}
.badge.ok{color:var(--ok);border-color:rgba(52,211,153,.32);background:rgba(52,211,153,.10)}
.badge.warn{color:var(--warn);border-color:rgba(251,191,36,.32);background:rgba(251,191,36,.10)}
.badge.bad{color:var(--bad);border-color:rgba(251,113,133,.32);background:rgba(251,113,133,.10)}
.chip{font-family:var(--mono);font-size:11px;letter-spacing:.04em;padding:3px 9px;border-radius:var(--r-xs);
  background:var(--bg-3);border:1px solid var(--line-2);color:var(--tx-2)}
.dot-i{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}
/* clickable graph connection / search rows — walk the graph by clicking through */
.nbr-row{background:transparent;border:1px solid transparent;transition:background .12s,border-color .12s}
.nbr-row:hover{background:var(--bg-2);border-color:var(--line)}

/* primitive color helpers — set --ac for any subtree */
.c-Location{--ac:var(--l)} .c-Entity{--ac:var(--e)} .c-Asset{--ac:var(--a)}
.c-Product{--ac:var(--p)} .c-Event{--ac:var(--ev)} .c-Document{--ac:var(--d)}

/* ── Buttons — the brand's sharp mono-uppercase control ────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;
  border-radius:var(--r-xs);border:1px solid var(--line);background:transparent;color:var(--tx);
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  white-space:nowrap;transition:.15s}
.btn:hover{border-color:rgba(122,168,255,.55);color:var(--steel-soft);background:rgba(122,168,255,.06)}
/* the platform's signature control: saturated blue gradient, white type */
.btn.primary{background:linear-gradient(140deg,#2563eb,#0ea5e9);border-color:rgba(147,197,253,.55);
  color:#fff;font-weight:600;box-shadow:0 10px 26px -14px rgba(59,130,246,.6)}
.btn.primary:hover{background:linear-gradient(140deg,#3b82f6,#38bdf8);border-color:rgba(191,219,254,.75);color:#fff}
.btn.ghost{border-color:transparent;color:var(--tx-2);background:transparent}
.btn.ghost:hover{background:var(--bg-2);color:var(--tx);border-color:transparent}
.btn.sm{padding:6px 11px;font-size:10px;letter-spacing:.1em}
.btn:disabled{opacity:.45;cursor:not-allowed}
/* brand-lane variants — paint inside the lanes */
.btn.coral{background:var(--coral);border-color:var(--coral);color:#fff}
.btn.coral:hover{background:var(--coral-soft);border-color:var(--coral-soft);color:#fff}
.btn.emerald{background:var(--signal);border-color:var(--signal);color:#04120c}
.btn.weaver{background:var(--weaver);border-color:var(--weaver);color:#031316}
.btn.weaver:hover{background:var(--weaver-soft);border-color:var(--weaver-soft);color:#031316}

/* ── Tables ────────────────────────────────────────────────────────────────── */
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;
  color:var(--tx-3);font-weight:500;padding:10px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line-2);color:var(--tx-2)}
.tbl tr:hover td{background:rgba(122,168,255,.04)}
.tbl td b{color:var(--tx);font-weight:600}

/* ── Inputs ────────────────────────────────────────────────────────────────── */
.input{width:100%;padding:11px 14px;border:1px solid var(--line);border-radius:var(--r-s);
  background:var(--bg-1);color:var(--tx);outline:none;transition:.14s}
.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(122,168,255,.16)}
.input::placeholder{color:var(--tx-3)}

/* ── Bars / meters ─────────────────────────────────────────────────────────── */
.meter{height:7px;border-radius:6px;background:var(--bg-3);overflow:hidden}
.meter>i{display:block;height:100%;border-radius:6px;background:var(--ac,var(--brand))}

/* ── intelWeaver — the agent register (Talk, agent actions) ────────────────── */
.agent-dot{width:7px;height:7px;border-radius:50%;background:var(--weaver);
  box-shadow:0 0 10px var(--weaver);display:inline-block;flex-shrink:0}
.agent-dot.pulse{animation:iw-pulse 1.6s ease-in-out infinite}
@keyframes iw-pulse{0%,100%{opacity:1;box-shadow:0 0 8px var(--weaver)}50%{opacity:.5;box-shadow:0 0 18px var(--weaver)}}
.agent-pill{display:inline-flex;align-items:center;gap:7px;padding:4px 10px;font-family:var(--mono);
  font-size:10px;letter-spacing:.14em;text-transform:uppercase;border-radius:999px;
  border:1px solid currentColor;color:var(--weaver);background:var(--weaver-glow)}

/* ── States ────────────────────────────────────────────────────────────────── */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  padding:62px 20px;text-align:center;color:var(--tx-3)}
.empty .big{font-size:34px;opacity:.55}
.empty>div:nth-child(2){font-family:var(--font-display);font-style:italic;font-size:22px;color:var(--tx-2)!important;font-weight:400!important}
.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid rgba(122,168,255,.2);
  border-top-color:var(--brand);animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.center{display:grid;place-items:center;height:100%;width:100%}

/* Arero7 loader — the house mark in motion: two coral pills + three rings pulsing
   in a staggered wave. The brand's signature loading state (replaces the ring spinner). */
.arero-loader{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:18px;line-height:0}
.arero-loader i{display:block;animation:arero-pulse 1.4s ease-in-out infinite;will-change:transform,opacity}
.arero-loader .pill{width:26px;height:13px;border-radius:7px;background:var(--coral)}
.arero-loader .ring{width:13px;height:13px;border-radius:50%;border:2px solid var(--coral);background:transparent}
.arero-loader i:nth-child(2){animation-delay:.15s}
.arero-loader i:nth-child(3){animation-delay:.3s}
.arero-loader i:nth-child(4){animation-delay:.45s}
.arero-loader i:nth-child(5){animation-delay:.6s}
.arero-loader.sm{gap:3px;height:10px}
.arero-loader.sm .pill{width:13px;height:6px;border-radius:4px}
.arero-loader.sm .ring{width:6px;height:6px;border-width:1.5px}
@keyframes arero-pulse{0%,100%{opacity:.3;transform:scale(.82)}50%{opacity:1;transform:scale(1)}}

/* intelWeaver bird — the agent's living mark. Gentle flutter while thinking, a slow
   hover at rest. Cyan glow ties it to the weaver register. */
.iw-bird{display:inline-block;object-fit:contain}
.iw-bird.flutter{animation:iw-flutter 1.6s ease-in-out infinite;transform-origin:50% 60%}
.iw-bird.float{animation:iw-float 4.5s ease-in-out infinite}
@keyframes iw-flutter{0%,100%{transform:rotate(0) scale(1)}25%{transform:rotate(-3deg) scale(1.03)}75%{transform:rotate(3deg) scale(.98)}}
@keyframes iw-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* ── Entrance / auth ───────────────────────────────────────────────────────── */
.gate{height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden}
.gate::before{content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(180,200,240,.09) 1px, transparent 1px);background-size:3px 3px;
  pointer-events:none}
.gate::after{content:'';position:absolute;width:820px;height:820px;border-radius:50%;top:-340px;left:50%;
  transform:translateX(-50%);pointer-events:none;
  background:radial-gradient(circle, rgba(52,211,153,.06), rgba(122,168,255,.04) 42%, transparent 70%)}
.gate-card{position:relative;width:100%;max-width:404px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,.006)),var(--bg-1);
  border:1px solid var(--line);border-radius:18px;padding:36px;box-shadow:var(--shadow)}
.gate-orbs{display:flex;gap:8px;justify-content:center;margin-bottom:22px}
.gate-orbs i{width:12px;height:12px;border-radius:50%}
.fld{margin-bottom:14px}
.fld label{display:block;font-family:var(--mono);font-size:10px;color:var(--tx-3);margin-bottom:7px;
  font-weight:500;letter-spacing:.14em;text-transform:uppercase}

/* ── The fold — the platform's motion signature ────────────────────────────
   Everything in UDF is a fold or an unfold of the graph, so every surface
   arrives the same way: it unfolds. One motion, everywhere. */
.fade{animation:unfold .42s cubic-bezier(.16,1,.3,1);transform-origin:50% 0}
@keyframes unfold{from{opacity:0;transform:perspective(1400px) rotateX(-5deg) translateY(12px)}
  to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.fade{animation:fade .25s ease}}

/* ─────────────────────────────────────────────────────────────────────────
   Platform chrome — the head-of-design layer (Test-UDF-layout port).
   Grouped rail, the ⌘K Ask bar, the persistent intelWeaver dock, the emerald
   provenance thread, the LEAPED legend, page heroes, pipeline, tiles.
   ───────────────────────────────────────────────────────────────────────── */

/* ── Sidebar rail — grouped, mono section labels ───────────────────────────── */
.sidebar{padding:18px 12px 14px;gap:2px}
.brand{padding:6px 8px 16px}
.brand-mark svg{animation:udf-breathe 6s ease-in-out infinite}
@keyframes udf-breathe{0%,100%{filter:drop-shadow(0 4px 12px rgba(122,168,255,.18))}
  50%{filter:drop-shadow(0 4px 18px rgba(122,168,255,.42))}}
.brand-by{font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--tx-3);margin-top:5px;display:flex;align-items:center;gap:5px}
.brand-by b{color:var(--coral);font-weight:600}

.rail-group{margin-top:14px}
.rail-group:first-child{margin-top:2px}
.rail-label{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--tx-3);padding:6px 11px 7px;display:flex;align-items:center;gap:8px}
.rail-label::after{content:'';flex:1;height:1px;background:var(--line-2)}
.nav-item{position:relative}
.nav-item .ic svg{width:17px;height:17px;display:block;margin:0 auto}
.nav-item .tail{margin-left:auto}
.nav-item.iw.on{background:var(--weaver-glow);border-color:rgba(34,211,238,.34);box-shadow:inset 2px 0 0 var(--weaver)}
.nav-item.iw.on .ic{filter:drop-shadow(0 0 7px var(--weaver))}

.build-stamp{font-family:var(--mono);font-size:8.5px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--tx-3);padding:8px 9px 2px;display:flex;align-items:center;gap:7px}
.build-stamp .thread-dot{width:5px;height:5px;border-radius:50%;background:var(--signal);box-shadow:0 0 7px var(--signal)}

/* ── Topbar — crumb + the ⌘K Ask (intelWeaver entry) ───────────────────────── */
.topbar{padding:0 22px 0 26px;gap:14px;overflow:hidden}
.topbar h1{flex-shrink:0}
.topbar .crumb b{color:var(--tx-2);font-weight:500}
.cmdk{display:flex;align-items:center;gap:10px;height:38px;padding:0 12px 0 14px;
  flex:1 1 auto;min-width:180px;max-width:440px;
  border:1px solid var(--line);border-radius:var(--r-xs);background:var(--bg-1);color:var(--tx-3);
  cursor:text;transition:.15s}
.cmdk:hover{border-color:rgba(34,211,238,.4);color:var(--tx-2)}
.cmdk .iw-mini{width:18px;height:18px;object-fit:contain;flex-shrink:0;
  filter:drop-shadow(0 0 5px var(--weaver-glow))}
.cmdk .ph{flex:1;font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmdk .kbd{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;padding:2px 6px;border-radius:4px;
  border:1px solid var(--line);color:var(--tx-3);background:var(--bg-2)}
.top-ent{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--tx-3);
  border:1px solid var(--line-2);border-radius:var(--r-xs);padding:6px 10px;background:rgba(10,19,38,.4);
  flex-shrink:0;white-space:nowrap;max-width:220px;overflow:hidden;text-overflow:ellipsis}
.top-ent b{color:var(--tx-2);font-weight:500}
@media (max-width:1080px){.top-ent{display:none}.topbar .crumb{display:none}}

/* ── Page hero — the editorial serif moment a screen can open on ───────────── */
.phero{display:flex;align-items:flex-start;gap:24px;justify-content:space-between;flex-wrap:wrap}
.phero .lede{min-width:0}
.phero h1.big{font-size:46px;margin:12px 0 0;line-height:1.02}
.phero .sub{color:var(--tx-2);font-size:14.5px;margin-top:12px;max-width:60ch}
.phero .sub b{color:var(--tx);font-weight:600}
.phero .acts{display:flex;gap:10px;flex-shrink:0;padding-top:6px}
.eyebrow .thread-dot{width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}

/* ── The provenance thread — every output shows the fold it came from ──────── */
.prov{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.04em;color:var(--signal)}
.prov .line{width:26px;height:1px;background:linear-gradient(90deg,transparent,var(--signal));position:relative}
.prov .line::after{content:'';position:absolute;right:0;top:-1.5px;width:4px;height:4px;border-radius:50%;
  background:var(--signal);box-shadow:0 0 7px var(--signal)}
.prov b{color:var(--tx-2);font-weight:500}

/* ── LEAPED legend — the six-primitive data language, made explicit ────────── */
.legend{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:13px 18px;
  border:1px solid var(--line-2);border-radius:var(--r-s);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}
.legend .lg-title{font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--tx-3)}
.legend .lg{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;
  color:var(--tx-2);letter-spacing:.02em}
.legend .lg .sw{width:9px;height:9px;border-radius:50%;background:var(--ac);box-shadow:0 0 8px var(--ac)}

/* ── pstat extensions — ghost glyph + share bar ────────────────────────────── */
.pstat .ic svg{width:19px;height:19px;display:block}
.pstat .glyph{position:absolute;right:-14px;bottom:-16px;opacity:.05;color:var(--ac)}
.pstat .glyph svg{width:96px;height:96px}
.pstat .share{position:absolute;bottom:0;left:0;height:2px;background:var(--ac);opacity:.5}
.pstat.click{cursor:pointer}

/* ── intelWeaver — the living agent presence ───────────────────────────────── */
.iw-card{border:1px solid rgba(34,211,238,.26);border-radius:var(--r);
  background:linear-gradient(180deg,var(--weaver-glow),transparent),var(--bg-1);padding:18px;position:relative;overflow:hidden}
.iw-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--weaver)}
.iw-head{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.iw-avatar{width:34px;height:34px;border-radius:10px;background:rgba(34,211,238,.1);
  border:1px solid rgba(34,211,238,.3);display:grid;place-items:center;flex-shrink:0}
.iw-avatar img{width:24px;height:24px;object-fit:contain}
.iw-head .who{font-weight:600;font-size:13px;color:var(--weaver-soft);letter-spacing:.01em}
.iw-head .role{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx-3);margin-top:2px}
.iw-body{font-size:14px;color:var(--tx);line-height:1.6;text-wrap:pretty}
.iw-body .serif{font-size:18px}
.iw-body em{color:var(--weaver-soft);font-style:normal}

/* the persistent dock on the right of the shell — unfolds open */
.app{grid-template-columns:var(--sidebar) 1fr;transition:grid-template-columns .28s ease}
.app.dock-open{grid-template-columns:var(--sidebar) 1fr var(--dock)}
.iw-dock{display:none;flex-direction:column;min-height:0;border-left:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-1),var(--bg))}
.app.dock-open .iw-dock{display:flex}
.dock-h{height:62px;flex-shrink:0;border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:11px;padding:0 16px;background:rgba(10,19,38,.5);backdrop-filter:blur(8px)}
.dock-h .bird{width:26px;height:26px;object-fit:contain;filter:drop-shadow(0 0 8px var(--weaver-glow))}
.dock-h .t{font-weight:600;font-size:14px}
.dock-h .t .w{color:var(--weaver)}
.dock-h .st{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-3)}
.dock-body{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:14px}
.dock-foot{flex-shrink:0;border-top:1px solid var(--line);padding:14px 16px}
@media (max-width:1200px){
  .app.dock-open{grid-template-columns:var(--sidebar) 1fr}
  .app.dock-open .iw-dock{display:flex;position:fixed;top:0;right:0;bottom:0;width:min(360px,90vw);
    z-index:60;box-shadow:-30px 0 70px -30px rgba(0,0,0,.8)}
}

/* chat bubbles (dock; Talk keeps its own richer layout) */
.msg{display:flex;gap:11px;align-items:flex-start}
.msg .b{padding:11px 14px;border-radius:12px;font-size:13.5px;line-height:1.55;max-width:82%;
  white-space:pre-wrap;word-break:break-word}
.msg.user{justify-content:flex-end}
.msg.user .b{background:rgba(122,168,255,.12);border:1px solid rgba(122,168,255,.26);color:var(--tx)}
.msg.iw .b{background:var(--bg-2);border:1px solid var(--line);color:var(--tx)}
.msg.iw .av{width:28px;height:28px;border-radius:8px;background:rgba(34,211,238,.1);
  border:1px solid rgba(34,211,238,.3);display:grid;place-items:center;flex-shrink:0}
.msg.iw .av img{width:19px;height:19px;object-fit:contain}
.msg .b .src{display:block;margin-top:9px;padding-top:9px;border-top:1px solid var(--line-2)}

.ask-bar{display:flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:var(--r-s);
  background:var(--bg-1);padding:4px 4px 4px 14px;transition:.15s}
.ask-bar:focus-within{border-color:rgba(34,211,238,.5);box-shadow:0 0 0 3px var(--weaver-glow)}
.ask-bar input{flex:1;background:none;border:none;outline:none;font-size:13.5px;color:var(--tx);min-width:0}
.ask-bar input::placeholder{color:var(--tx-3)}

/* ── Pipeline — the unfold made visible, step by step ──────────────────────── */
.pipe{display:flex;align-items:stretch;gap:0}
.pipe .step{flex:1;position:relative;padding:16px 18px;border:1px solid var(--line);background:var(--bg-1)}
.pipe .step:first-child{border-radius:var(--r-s) 0 0 var(--r-s)}
.pipe .step:last-child{border-radius:0 var(--r-s) var(--r-s) 0}
.pipe .step + .step{border-left:none}
.pipe .step .n{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--tx-3)}
.pipe .step .h{font-weight:600;font-size:13.5px;margin-top:7px;color:var(--tx)}
.pipe .step .d{font-size:12px;color:var(--tx-2);margin-top:5px;line-height:1.5}
.pipe .step.done .h{color:var(--signal)}
.pipe .step.active{background:linear-gradient(180deg,rgba(122,168,255,.08),transparent),var(--bg-1);border-color:rgba(122,168,255,.4)}

/* ── tiles + flow chips + meta rows ────────────────────────────────────────── */
.tile{border:1px solid var(--line);border-radius:var(--r);padding:18px;background:var(--bg-1);
  transition:.15s;cursor:pointer;display:flex;flex-direction:column;gap:10px;min-height:150px}
.tile:hover{transform:translateY(-2px);border-color:rgba(122,168,255,.35);box-shadow:0 16px 40px -30px rgba(0,0,0,.7)}
.tile .th{display:flex;align-items:center;gap:10px}
.tile .th .nm{font-weight:600;font-size:14px}
.tile .desc{font-size:12.5px;color:var(--tx-2);line-height:1.5;flex:1}
.tile .foot{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10px;
  letter-spacing:.06em;color:var(--tx-3);text-transform:uppercase}
.flow-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.flow-node{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:var(--r-s);
  border:1px solid var(--line);background:var(--bg-2);font-size:12.5px;color:var(--tx)}
.flow-arrow{color:var(--tx-3);font-family:var(--mono)}
.krow{display:flex;align-items:center;justify-content:space-between;padding:11px 2px;
  border-bottom:1px solid var(--line-2)}
.krow:last-child{border-bottom:none}
.krow .k{color:var(--tx-2);font-size:13px}
.krow .v{font-family:var(--mono);font-size:12.5px;color:var(--tx);font-variant-numeric:tabular-nums}
.metric-big{font-family:var(--mono);font-size:34px;font-weight:600;letter-spacing:-.02em;line-height:1;color:var(--ac,var(--tx))}
.metric-lbl{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--tx-3);margin-top:9px}

/* ── richest-types rows — name · primitive · count over a share track ──────── */
.rtype{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:16px;
  padding:12px 8px;border-radius:var(--r-s);border:1px solid transparent;transition:.12s;cursor:pointer}
.rtype:hover{background:var(--bg-2);border-color:var(--line)}
.rtype .nm{display:flex;align-items:center;gap:11px;font-weight:500;color:var(--tx);font-size:13.5px;min-width:0}
.rtype .nm>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rtype .dot-i{box-shadow:0 0 8px var(--ac);background:var(--ac)}
.rtype .prim{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ac);
  min-width:82px;text-align:left;opacity:.9}
.rtype .v{font-family:var(--mono);font-size:13px;color:var(--tx-2);font-variant-numeric:tabular-nums}
.rtype .track{grid-column:1/-1;height:3px;border-radius:3px;background:var(--bg-3);overflow:hidden;margin-top:-2px}
.rtype .track i{display:block;height:100%;background:var(--ac);opacity:.55;border-radius:3px}

/* ── Explore — searchbar + primitive filter chips + result rows ────────────── */
.searchbar{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:var(--r-s);
  background:var(--bg-1);padding:14px 18px}
.searchbar svg{width:18px;height:18px;color:var(--tx-3);flex-shrink:0}
.searchbar input{flex:1;background:none;border:none;outline:none;font-size:16px;color:var(--tx);
  font-family:var(--font-body);min-width:0}
.searchbar input::placeholder{color:var(--tx-3)}
.filter-chips{display:flex;gap:8px;flex-wrap:wrap}
.fchip{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  padding:6px 11px;border-radius:999px;border:1px solid var(--line);color:var(--tx-2);background:var(--bg-2);
  cursor:pointer;transition:.13s;display:inline-flex;align-items:center;gap:7px}
.fchip:hover{border-color:var(--ac,var(--steel));color:var(--tx)}
.fchip.on{border-color:var(--ac,var(--steel));color:var(--tx);background:color-mix(in oklch,var(--ac,var(--steel)) 12%,transparent)}
.fchip .sw{width:7px;height:7px;border-radius:50%;background:var(--ac,var(--steel));box-shadow:0 0 6px var(--ac,var(--steel))}
.result{display:flex;align-items:center;gap:14px;padding:13px 16px;border:1px solid transparent;
  border-radius:var(--r-s);cursor:pointer;transition:.12s}
.result:hover{background:var(--bg-2);border-color:var(--line)}
.result .tag{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;
  padding:4px 8px;border-radius:5px;color:var(--ac);border:1px solid var(--ac);background:color-mix(in oklch,var(--ac) 12%,transparent)}
.result .nm{font-weight:500;color:var(--tx);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.result .meta{font-family:var(--mono);font-size:11px;color:var(--tx-3)}

/* ── health bars ───────────────────────────────────────────────────────────── */
.hbars{display:flex;flex-direction:column;gap:14px}
.hbar .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
.hbar .top .l{font-size:13px;color:var(--tx-2)}
.hbar .top .r{font-family:var(--mono);font-size:12px;color:var(--ac,var(--tx-2));font-variant-numeric:tabular-nums}

/* ── Graph stage — the live canvas with overlay chrome ─────────────────────── */
.graph-stage{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  background:radial-gradient(circle at 50% 40%, rgba(122,168,255,.08), transparent 60%),var(--bg);
  min-height:560px}
.graph-stage canvas{display:block;width:100%;height:100%}
.graph-overlay{position:absolute;inset:0;pointer-events:none}
.graph-chip{position:absolute;top:16px;left:16px;pointer-events:auto}
.graph-legend{position:absolute;bottom:16px;left:16px;display:flex;gap:12px;flex-wrap:wrap;
  padding:10px 14px;border-radius:var(--r-s);background:rgba(10,19,38,.7);backdrop-filter:blur(8px);
  border:1px solid var(--line);pointer-events:auto}
.node-inspect{position:absolute;top:16px;right:16px;width:266px;pointer-events:auto;
  background:linear-gradient(180deg,rgba(255,255,255,.03),transparent),var(--bg-1);
  border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow)}

/* ── time scrubber — frame the window of reality you're looking at ─────────── */
.tscrub{display:flex;align-items:center;gap:12px;padding:9px 14px;border:1px solid var(--line-2);
  border-radius:var(--r-s);background:linear-gradient(180deg,rgba(255,255,255,.015),transparent)}
.tscrub .lab{font-family:var(--mono);font-size:10px;color:var(--tx-3);letter-spacing:.06em;white-space:nowrap}
.tscrub .rails{position:relative;flex:1;height:22px;min-width:160px}
.tscrub .rails::before{content:'';position:absolute;left:0;right:0;top:50%;height:2px;margin-top:-1px;
  background:var(--bg-3);border-radius:2px}
.tscrub .win{position:absolute;top:50%;height:2px;margin-top:-1px;background:var(--steel);border-radius:2px;
  box-shadow:0 0 8px rgba(122,168,255,.5);pointer-events:none}
.tscrub input[type=range]{position:absolute;inset:0;width:100%;margin:0;appearance:none;-webkit-appearance:none;
  background:none;pointer-events:none;height:22px}
.tscrub input[type=range]::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;pointer-events:auto;
  width:13px;height:13px;border-radius:50%;background:var(--steel);border:2px solid #0a1326;
  box-shadow:0 0 8px rgba(122,168,255,.6);cursor:ew-resize}
.tscrub input[type=range]::-moz-range-thumb{pointer-events:auto;width:13px;height:13px;border-radius:50%;
  background:var(--steel);border:2px solid #0a1326;cursor:ew-resize}

/* ── dropzone — where evidence enters the field ────────────────────────────── */
.dropzone{border:1.5px dashed var(--line);border-radius:var(--r);padding:44px 24px;text-align:center;
  background:radial-gradient(circle at 50% 0%, rgba(122,168,255,.06), transparent 70%);transition:.15s}
.dropzone:hover,.dropzone.over{border-color:rgba(122,168,255,.5);
  background:radial-gradient(circle at 50% 0%, rgba(122,168,255,.12), transparent 70%)}
.dropzone .big{font-family:var(--font-display);font-style:italic;font-size:26px;color:var(--tx)}
.placeholder-note{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--tx-3)}
