/* ============================================================
   CodeNSM PUBLIC DEMO — tabbed preview extras
   Loaded on /codensm/demo* pages alongside codensm.css + product.css
   ============================================================ */

/* ---- demo section tabs (extends .cn-tabs from product.css) ---- */
.demo-tabs{margin:18px 0 4px;align-items:center;flex-wrap:wrap;width:auto;max-width:100%}
.demo-badge{margin-left:auto;padding:5px 12px;border-radius:16px;white-space:nowrap;
  font-family:var(--mono);font-size:.58rem;font-weight:600;letter-spacing:.14em;
  color:var(--mint);border:1px solid rgba(126,240,201,.35);background:rgba(126,240,201,.06)}
@media(max-width:760px){.demo-badge{margin-left:0;order:-1;width:max-content}}

/* ---- slim conversion header on every demo sub-page ---- */
.demo-convert{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:16px;
  border:1px solid var(--line);border-radius:14px;padding:12px 16px;
  background:rgba(126,240,201,.04)}
.demo-convert .note{font-family:var(--mono);font-size:.68rem;color:var(--soft);
  letter-spacing:.03em;line-height:1.6;max-width:52ch}
.demo-convert .note b{color:var(--mint)}
.demo-convert .cta{display:flex;gap:10px;flex-wrap:wrap;margin-left:auto}
@media(max-width:760px){.demo-convert .cta{margin-left:0}}

/* ---- dashboard: public NSM hero ---- */
.demo-nsm{display:flex;align-items:baseline;gap:12px;margin:8px 0 6px}
.demo-nsm .v{font-family:var(--mono);font-size:3.2rem;font-weight:700;color:var(--ink);line-height:1}
.demo-nsm .d{font-family:var(--mono);font-size:1rem;color:var(--dim)}
.demo-nsm-read{color:var(--soft);font-size:.9rem;max-width:56ch;margin-top:6px}
.demo-kpis{display:flex;gap:22px;flex-wrap:wrap;margin-top:16px;
  font-family:var(--mono);font-size:.72rem;color:var(--dim)}
.demo-kpis b{color:var(--ink);font-size:1rem;margin-right:4px}
.demo-drill-note{font-family:var(--mono);font-size:.66rem;color:var(--dim);margin-top:10px}
.demo-drill-note a{color:var(--mint)}

/* warming-up empty state */
.demo-warm{border:1px dashed var(--line-lum);border-radius:18px;padding:44px 30px;
  margin-top:24px;text-align:center}
.demo-warm h2{font-size:1.25rem;margin-bottom:8px}
.demo-warm p{color:var(--soft);max-width:58ch;margin:0 auto;font-size:.92rem}

/* ---- flow teaser: hand-authored sample BPMN ---- */
.demo-bpmn-stage{position:relative;padding:26px 18px 18px;overflow-x:auto;
  background:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:28px 28px}
.demo-bpmn{display:block;width:100%;min-width:640px;height:auto}
.demo-bpmn text{font-family:var(--mono)}
.demo-bpmn .db-lbl{fill:#e7ebf3;font-size:11px;font-weight:600}
.demo-bpmn .db-sub{fill:#6d7589;font-size:8.5px}
.demo-bpmn .db-edge-lbl{fill:#8b93a7;font-size:9px}
.demo-bpmn .db-start,.demo-bpmn .db-end{fill:rgba(126,240,201,.14);stroke:rgba(126,240,201,.65);stroke-width:1.5}
.demo-bpmn .db-task{fill:rgba(125,215,255,.10);stroke:rgba(125,215,255,.55);stroke-width:1.2;rx:9}
.demo-bpmn .db-decision{fill:rgba(239,217,163,.12);stroke:rgba(239,217,163,.6);stroke-width:1.2}
.demo-bpmn .db-loop{fill:rgba(198,184,242,.12);stroke:rgba(198,184,242,.6);stroke-width:1.2;rx:9}
.demo-bpmn .db-err{fill:rgba(241,133,127,.15);stroke:#f1857f;stroke-width:1.5}
.demo-bpmn .db-edge{fill:none;stroke:rgba(255,255,255,.22);stroke-width:1.3}
.demo-bpmn .db-arrow{fill:rgba(255,255,255,.35)}
.demo-bpmn .db-back{fill:none;stroke:rgba(198,184,242,.55);stroke-width:1.3;stroke-dasharray:5 7;
  animation:db-back 2.4s linear infinite}
@keyframes db-back{from{stroke-dashoffset:0}to{stroke-dashoffset:-48}}

/* traveling token: loops along the happy path forever */
.demo-dot{fill:var(--mint);filter:drop-shadow(0 0 5px rgba(126,240,201,.8));
  offset-path:path('M64 120 L242 120 L258 120 L342 120 L378 120 L532 120 L592 120');
  animation:db-travel 5.5s cubic-bezier(.45,.05,.55,.95) infinite}
@keyframes db-travel{
  0%{offset-distance:0%;opacity:0}
  6%{opacity:1}
  94%{opacity:1}
  100%{offset-distance:100%;opacity:0}}
@media(prefers-reduced-motion:reduce){
  .demo-dot{animation:none;opacity:0}
  .demo-bpmn .db-back{animation:none;stroke-dasharray:5 7}}

/* "SAMPLE" watermark stamp (flow stage + dev card) */
.demo-stamp{position:absolute;top:14px;right:16px;z-index:3;transform:rotate(6deg);
  font-family:var(--mono);font-size:.62rem;font-weight:700;letter-spacing:.28em;
  color:var(--peach);border:1.5px solid rgba(244,203,168,.55);border-radius:6px;
  padding:4px 10px 4px 12px;background:rgba(10,12,17,.6);pointer-events:none}

/* ---- teaser shared bits ---- */
.demo-unlocks{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px;max-width:64ch}
.demo-unlocks li{position:relative;padding-left:26px;color:var(--soft);font-size:.9rem;line-height:1.6}
.demo-unlocks li::before{content:"◆";position:absolute;left:2px;top:1px;
  color:var(--mint);font-size:.7rem}
.demo-unlocks li b{color:var(--ink)}
.demo-privacy{margin-top:18px;font-size:.9rem;color:var(--soft)}
.demo-privacy b{color:var(--mint)}
.upsell .demo-unlocks{margin:20px auto 0;text-align:left}

/* ---- devs teaser: single sample card ---- */
.demo-dev-wrap{position:relative;max-width:430px;margin-top:20px}
.demo-dev-wrap .dev-card{opacity:.96}
.demo-framing{border-left:2px solid rgba(126,240,201,.5);padding:4px 0 4px 14px;
  margin-top:20px;color:var(--soft);font-size:.9rem;max-width:66ch}
.demo-framing b{color:var(--ink)}

/* ============================================================
   2026-07 UI/IA consistency sweep additions
   ============================================================ */

/* ---- demo flow: multiple real BPMN pools stacked ---- */
.demo-flow-pool{margin-top:18px}
.demo-flow-pool .demo-flow-src{color:var(--dim);word-break:break-all}
@media(max-width:760px){.demo-flow-pool .demo-flow-src{margin-left:0;width:100%}}

/* ---- fictional-persona framing note (devs list + persona detail) ---- */
.fiction-note{font-family:var(--mono);font-size:.72rem;color:var(--soft);letter-spacing:.03em;
  max-width:72ch;line-height:1.7;margin:14px 0 0;padding:12px 16px;border:1px dashed var(--line);
  border-radius:12px;background:rgba(255,255,255,.015)}
.fiction-note b{color:var(--mint)}

/* ---- persona portfolio page ---- */
.persona-hero .emp-role{color:var(--sky)}
.persona-hero h1{font-family:var(--mono);letter-spacing:.01em}

/* ======================================================================
   MERMAID DEMO FLOW POOLS (demo_flow.html + flow-mermaid.js)
   ====================================================================== */
.demo-flow-pool{margin-top:16px}
.demo-flow-pool .mermaid-canvas{min-height:160px}
.demo-flow-pool .mermaid-fn-name{font-size:.9rem}

/* ============================================================
   2026-07 readability pass
   ============================================================ */

/* ---- "How to read this office" — the standard ontology strip ---- */
.onto-strip{margin:10px 0 14px;border:1px solid var(--line);border-radius:14px;
  background:rgba(255,255,255,.015)}
.onto-strip summary{display:flex;align-items:center;gap:10px;cursor:pointer;
  padding:10px 16px;list-style:none;user-select:none}
.onto-strip summary::-webkit-details-marker{display:none}
.onto-strip summary:hover{background:rgba(255,255,255,.02);border-radius:14px}
.onto-q{flex:0 0 auto;width:18px;height:18px;display:inline-flex;align-items:center;
  justify-content:center;border-radius:50%;border:1px solid rgba(126,240,201,.45);
  color:var(--mint);font-family:var(--mono);font-size:.62rem;font-weight:700}
.onto-t{font-family:var(--mono);font-size:.72rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--ink)}
.onto-hint{font-family:var(--mono);font-size:.62rem;color:var(--dim);letter-spacing:.04em}
.onto-caret{margin-left:auto;color:var(--dim);font-size:.7rem;transition:transform .2s}
.onto-strip[open] .onto-caret{transform:rotate(180deg)}
.onto-body{padding:4px 16px 16px;border-top:1px solid var(--line)}
.onto-sec{margin-top:12px}
.onto-h{font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--dim);margin-bottom:8px}
.onto-roles{display:grid;grid-template-columns:repeat(3,1fr);gap:7px 18px}
@media(max-width:980px){.onto-roles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.onto-roles{grid-template-columns:1fr}}
.onto-role{font-size:.76rem;line-height:1.5;color:var(--soft)}
.onto-role b{color:var(--ink);font-weight:600}
.onto-role b::after{content:" — ";color:var(--dim);font-weight:400}
.onto-states{display:flex;flex-wrap:wrap;gap:6px 14px}
.onto-state{display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.onto-state em{font-style:normal;font-size:.68rem;color:var(--dim)}

/* ---- dashboard lists: dim one-line job description under the alias ---- */
.wk-id .wk-desc{display:block;font-size:.68rem;font-style:italic;color:var(--dim);
  line-height:1.45;max-width:44ch;overflow:hidden;text-overflow:ellipsis;
  white-space:nowrap}

/* ---- employees roster: clickable rows + slide-in personnel panel ---- */
.emp-table tr.empd-row{cursor:pointer}
.emp-table tr.empd-row:focus-visible{outline:2px solid rgba(126,240,201,.6);
  outline-offset:-2px}
.emp-table tr.empd-on{background:rgba(126,240,201,.05)}

.empd-backdrop{position:fixed;inset:0;z-index:2147483645;background:rgba(4,8,16,.45);
  opacity:0;transition:opacity .22s ease}
.empd-backdrop.show{opacity:1}
.empd-panel{position:fixed;top:0;right:0;bottom:0;z-index:2147483646;
  width:min(360px,92vw);overflow-y:auto;padding:20px 22px 26px;
  border-left:1px solid rgba(255,255,255,.14);
  background:linear-gradient(180deg,rgba(19,24,38,.99),rgba(10,13,20,.99));
  box-shadow:-30px 0 60px -30px #000;font-family:var(--mono);
  transform:translateX(102%);transition:transform .24s ease;outline:none}
.empd-panel.show{transform:translateX(0)}
.empd-close{position:absolute;top:12px;right:12px;width:24px;height:24px;
  border-radius:7px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--dim);font-size:.66rem;line-height:1;cursor:pointer;font-family:var(--mono)}
.empd-close:hover{color:var(--ink);border-color:rgba(255,255,255,.3)}
.empd-alias{font-size:1.06rem;font-weight:700;color:var(--ink);word-break:break-all;
  padding-right:26px;line-height:1.3}
.empd-desc{font-style:italic;font-size:.74rem;color:var(--soft);line-height:1.55;
  margin:6px 0 0}
.empd-role{margin-top:14px;font-size:.72rem;line-height:1.55;color:var(--soft)}
.empd-role b{display:block;font-size:.62rem;letter-spacing:.11em;text-transform:uppercase;
  color:var(--sky);margin-bottom:2px}
.empd-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.empd-stats{margin-top:16px;border-top:1px solid var(--line);padding-top:6px}
.empd-stat{display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.empd-stat span{font-size:.62rem;letter-spacing:.09em;text-transform:uppercase;color:var(--dim)}
.empd-stat b{font-size:.8rem;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}
.empd-stat b.bad{color:#f1857f}
.empd-tests{margin-top:12px;font-size:.72rem}
.empd-note{margin-top:16px;font-size:.62rem;color:var(--dim);line-height:1.7}
@media(max-width:520px){.empd-panel{width:100vw;border-left:0}}
@media(prefers-reduced-motion:reduce){
  .empd-panel,.empd-backdrop{transition:none}}
