/* ============================================================
   Noema — product-screen internals rendered for the marketing
   site. These reproduce the REAL app structures (E2 process
   model, A9 discovery item, E3 fit-gap, E4 open points, F1
   deliverables) so the screens read as the actual product.
   ============================================================ */

/* ---------------- E2 · process model (hero) ---------------- */
.pm-toolbar { display:flex; align-items:center; gap:10px; flex-wrap:wrap; padding:10px 14px;
  border-bottom:1px solid var(--border-subtle); background:var(--bg-surface); }
.seg { display:inline-flex; background:var(--bg-subtle); border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); padding:2px; gap:2px; }
.seg button, .seg span { font-size:var(--text-xs); font-weight:500; color:var(--text-secondary);
  padding:4px 9px; border-radius:4px; border:none; background:transparent; line-height:1.2; cursor:pointer;
  white-space:nowrap; transition:background .14s var(--ease), color .14s var(--ease); }
.seg button:hover:not(.on) { color:var(--text-primary); background:color-mix(in oklab, var(--bg-hover) 60%, transparent); }
.seg .on { background:var(--bg-surface); color:var(--text-primary); box-shadow:var(--shadow-sm); font-weight:600; cursor:default; }
.seg .on.brandon { color:var(--brand-accent); }
.lens { display:inline-flex; align-items:center; gap:7px; font-size:var(--text-xs); font-weight:500;
  color:var(--text-secondary); border:1px solid var(--border-subtle); background:var(--bg-surface);
  border-radius:var(--radius-md); padding:5px 9px; }
.lens .code { font-family:var(--font-mono); font-size:10px; color:var(--scope-variant-fg);
  background:var(--scope-variant-bg); border-radius:3px; padding:1px 4px; }
.lvl-steps { display:inline-flex; gap:2px; }
.lvl-steps span { font-family:var(--font-mono); font-size:11px; color:var(--text-tertiary);
  padding:3px 8px; border:1px solid var(--border-subtle); border-radius:4px; }
.lvl-steps span.on { color:var(--text-primary); background:var(--bg-subtle); border-color:var(--border-default); font-weight:600; }

.pm-canvas { position:relative; padding:30px 26px 26px; min-height:300px; overflow:hidden; }
.pm-lane { display:flex; align-items:center; gap:0; }
.pnode { flex:0 0 auto; width:148px; background:var(--bg-surface); border:1px solid var(--border-default);
  border-radius:var(--radius-md); padding:9px 10px; position:relative; }
.pnode .psys { font-family:var(--font-mono); font-size:9.5px; color:var(--text-tertiary); line-height:1.3;
  text-transform:none; letter-spacing:0; margin-bottom:5px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pnode .pt { font-size:var(--text-sm); font-weight:500; color:var(--text-primary); line-height:1.25; }
.pnode .pbadges { display:flex; align-items:center; gap:5px; margin-top:8px; flex-wrap:wrap; }
.pnode.start, .pnode.endn { width:auto; background:var(--bg-subtle); border-radius:99px; padding:8px 14px; align-self:center; }
.pnode.start .pt, .pnode.endn .pt { font-weight:600; }
.pnode.forkn { border-color:color-mix(in oklab, var(--scope-variant-fg) 38%, transparent); }
.fit { display:inline-flex; align-items:center; gap:4px; font-size:10px; font-weight:600; line-height:1;
  padding:3px 6px; border-radius:99px; }
.fit-ok   { color:var(--confidence-high-fg);   background:var(--confidence-high-bg); }
.fit-cfg  { color:var(--finding-constraint-fg); background:var(--finding-constraint-bg); }
.fit-int  { color:var(--finding-risk-fg);       background:var(--finding-risk-bg); }
.fit-cust { color:var(--finding-pain-fg);       background:var(--finding-pain-bg); }
.minibadge { font-size:9.5px; font-weight:600; padding:2px 6px; border-radius:99px; line-height:1; }

/* connectors */
.pedge { flex:1 1 auto; min-width:24px; height:2px; align-self:center; position:relative; margin-top:0;
  background:var(--border-default); }
.pedge::after { content:""; position:absolute; right:-1px; top:-3px; border-left:6px solid var(--border-default);
  border-top:4px solid transparent; border-bottom:4px solid transparent; }
.pedge .elbl { position:absolute; top:-20px; left:50%; transform:translateX(-50%); font-family:var(--font-mono);
  font-size:9px; color:var(--text-tertiary); background:var(--bg-surface); padding:0 4px; white-space:nowrap; }

/* variant branch */
.pm-branch { display:flex; align-items:flex-start; gap:0; margin-top:6px; }
.branch-elbow { width:40px; height:46px; flex:0 0 auto; margin-top:-6px; }
.pnode.variant { border:1px solid color-mix(in oklab, var(--scope-variant-fg) 55%, transparent);
  background:color-mix(in oklab, var(--scope-variant-bg) 55%, var(--bg-surface)); }
.scope-tag { display:inline-flex; align-items:center; gap:4px; font-size:9.5px; font-weight:600; line-height:1;
  padding:2px 6px; border-radius:99px; color:var(--scope-variant-fg); background:var(--scope-variant-bg); }
.has-variants { display:inline-flex; align-items:center; gap:5px; font-size:10px; font-weight:500;
  color:var(--scope-variant-fg); background:var(--scope-variant-bg); border-radius:99px; padding:3px 8px; margin-top:8px; }
.pedge.variant-edge { background:transparent; }
.pedge.variant-edge::after { display:none; }

/* zoom cluster */
.zoomcluster { position:absolute; bottom:16px; right:16px; display:flex; flex-direction:column;
  background:var(--bg-surface); border:1px solid var(--border-default); border-radius:var(--radius-md);
  box-shadow:var(--shadow-sm); overflow:hidden; }
.zoomcluster button { width:30px; height:30px; display:grid; place-items:center; border:none; background:transparent;
  color:var(--text-secondary); border-bottom:1px solid var(--border-subtle); cursor:default; }
.zoomcluster button:last-child { border-bottom:none; }
.zoom-pct { position:absolute; bottom:16px; right:54px; font-family:var(--font-mono); font-size:10px;
  color:var(--text-tertiary); background:var(--bg-surface); border:1px solid var(--border-subtle);
  border-radius:var(--radius-sm); padding:3px 7px; }
.pm-hint { position:absolute; left:18px; bottom:14px; font-family:var(--font-mono); font-size:10px; color:var(--text-tertiary); }

/* ---------------- A9 · discovery item card ---------------- */
.di-card { background:var(--bg-surface); border:1px solid var(--border-default); border-radius:var(--radius-md);
  border-left:3px solid var(--finding-question-fg); padding:14px 16px; }
.di-card.verify { border-left-color:var(--finding-pain-fg); }
.di-top { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.di-num { font-family:var(--font-mono); font-size:var(--text-xs); color:var(--text-tertiary); margin-left:auto; }
.di-text { font-size:var(--text-md); font-weight:500; line-height:1.4; margin-top:10px; color:var(--text-primary); }
.di-prov { display:flex; align-items:center; gap:7px; margin-top:10px; font-size:var(--text-sm); color:var(--text-tertiary); }
.di-prov .ref { font-family:var(--font-mono); font-size:11px; color:var(--brand-accent);
  background:var(--brand-accent-tint); border-radius:4px; padding:1px 6px; }
.di-foot { display:flex; align-items:center; gap:8px; margin-top:12px; padding-top:12px; border-top:1px solid var(--border-subtle); flex-wrap:wrap; }
.di-disp { display:inline-flex; align-items:center; gap:6px; font-size:var(--text-sm); font-weight:500;
  color:var(--text-secondary); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:5px 10px; }
.kind-question    { color:var(--finding-question-fg);    background:var(--finding-question-bg); }
.kind-requirement { color:var(--finding-requirement-fg); background:var(--finding-requirement-bg); }
.kind-gap         { color:var(--finding-pain-fg);        background:var(--finding-pain-bg); }
.kind-decision    { color:var(--finding-decision-fg);    background:var(--finding-decision-bg); }
.kind-risk        { color:var(--finding-risk-fg);        background:var(--finding-risk-bg); }
.kind-variant     { color:var(--scope-variant-fg);       background:var(--scope-variant-bg); }
.kind-conflict    { color:var(--finding-conflict-fg);    background:var(--finding-conflict-bg); }

/* ---------------- E3 · fit-gap register row ---------------- */
.fg-row { background:var(--bg-surface); border:1px solid var(--border-default); border-radius:var(--radius-md);
  border-left:3px solid var(--confidence-high-fg); padding:14px 16px; }
.fg-row.cfg { border-left-color:var(--finding-constraint-fg); }
.fg-head { display:flex; align-items:flex-start; gap:10px; }
.fg-title { font-size:var(--text-md); font-weight:600; line-height:1.3; }
.fg-cap { font-size:var(--text-sm); color:var(--text-secondary); line-height:1.5; margin-top:8px; }
.fg-scopes { display:flex; align-items:center; gap:8px; margin-top:12px; flex-wrap:wrap;
  background:var(--bg-subtle); border:1px solid var(--border-subtle); border-radius:var(--radius-md); padding:10px 12px; }
.fg-scope { display:inline-flex; align-items:center; gap:6px; font-size:var(--text-xs); font-weight:600;
  background:var(--bg-surface); border:1px solid var(--border-subtle); border-radius:99px; padding:3px 9px 3px 7px; white-space:nowrap; }
.fg-scope .sc { font-family:var(--font-mono); font-size:10px; color:var(--text-tertiary); }
.fg-scopes .lab { font-size:var(--text-xs); color:var(--text-tertiary); margin-left:auto; }

/* ---------------- E4 · open point ---------------- */
.op-row { display:grid; grid-template-columns:auto 1fr auto; gap:14px; align-items:center;
  padding:14px 16px; border-top:1px solid var(--border-subtle); }
.op-row:first-child { border-top:none; }
.op-id { font-family:var(--font-mono); font-size:var(--text-xs); color:var(--text-tertiary); }
.op-desc { font-size:var(--text-base); font-weight:500; line-height:1.4; }
.op-meta { font-size:var(--text-sm); color:var(--text-secondary); margin-top:3px; }
.op-status { font-size:var(--text-xs); font-weight:600; padding:4px 9px; border-radius:99px; white-space:nowrap; }
.op-open  { color:var(--confidence-medium-fg); background:var(--confidence-medium-bg); }
.op-disc  { color:var(--status-edited-fg); background:var(--status-edited-bg); }
.op-res   { color:var(--status-locked-fg); background:var(--status-locked-bg); }

/* ---------------- F1 · deliverables workspace ---------------- */
.dlv-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:10px; }
.dlv-card { display:flex; align-items:center; gap:12px; padding:12px 14px; background:var(--bg-surface);
  border:1px solid var(--border-default); border-radius:var(--radius-md); }
.dlv-fmt { font-family:var(--font-mono); font-size:10px; font-weight:600; letter-spacing:.02em;
  padding:3px 7px; border-radius:4px; flex:0 0 auto; }
.fmt-xlsx { color:var(--confidence-high-fg); background:var(--confidence-high-bg); }
.fmt-pptx { color:var(--finding-risk-fg); background:var(--finding-risk-bg); }
.fmt-docx { color:var(--finding-requirement-fg); background:var(--finding-requirement-bg); }
.dlv-name { font-size:var(--text-base); font-weight:500; line-height:1.3; }
.dlv-sub { font-size:var(--text-xs); color:var(--text-tertiary); margin-top:2px; }

/* delegation split */
.deleg { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.deleg-card { background:var(--bg-surface); border:1px solid var(--border-default); border-radius:var(--radius-md); padding:16px; }
.deleg-card .owner { display:inline-flex; align-items:center; gap:7px; font-size:var(--text-xs); font-weight:600;
  padding:4px 10px; border-radius:99px; }
.owner-lead { color:var(--brand-accent); background:var(--brand-accent-tint); }
.owner-ai   { color:var(--text-secondary); background:var(--bg-subtle); border:1px solid var(--border-subtle); }
.deleg-row { display:flex; align-items:center; justify-content:space-between; gap:8px; padding:9px 0;
  border-top:1px solid var(--border-subtle); font-size:var(--text-sm); }
.deleg-row:first-of-type { border-top:none; }
.deleg-row .who { color:var(--text-primary); font-weight:500; }
.deleg-row .dur { font-family:var(--font-mono); font-size:11px; color:var(--text-tertiary); }

@media (max-width:560px) {
  .dlv-grid, .deleg { grid-template-columns:1fr; }
  .pm-branch { padding-left:0; }
  .op-row { grid-template-columns:1fr; gap:6px; }
}

/* ---------------- D2/D3 · live interview (voice + transcript) ---------------- */
.iv-grid { display:grid; grid-template-columns:1.45fr 1fr; }
.iv-left { border-right:1px solid var(--border-subtle); }
.iv-id { display:flex; align-items:center; gap:10px; padding:14px 16px; border-bottom:1px solid var(--border-subtle); }
.iv-avatar { width:34px; height:34px; border-radius:99px; display:grid; place-items:center; flex:0 0 auto;
  font-size:var(--text-sm); font-weight:600; background:var(--brand-accent-tint); color:var(--brand-accent);
  border:1px solid color-mix(in oklab, var(--brand-accent) 24%, transparent); }
.iv-id .who { font-size:var(--text-base); font-weight:600; line-height:1.2; }
.iv-id .role { font-size:var(--text-xs); color:var(--text-tertiary); margin-top:2px; }
.iv-listen { display:inline-flex; align-items:center; gap:8px; margin-left:auto; font-size:var(--text-xs); font-weight:600;
  color:var(--confidence-verify-fg); background:var(--confidence-verify-bg); border-radius:99px; padding:5px 11px; }
.wave { display:inline-flex; align-items:flex-end; gap:2px; height:13px; }
.wave i { width:2.5px; background:currentColor; border-radius:2px; height:100%; transform-origin:bottom;
  animation:listen 1s var(--ease) infinite; }
.wave i:nth-child(2){ animation-delay:.15s } .wave i:nth-child(3){ animation-delay:.3s }
.wave i:nth-child(4){ animation-delay:.45s } .wave i:nth-child(5){ animation-delay:.1s }
@media (prefers-reduced-motion: reduce) { .wave i { animation:none; height:60%; } }

.iv-transcript { padding:16px; display:flex; flex-direction:column; gap:16px; }
.iv-turn { display:flex; flex-direction:column; gap:5px; }
.iv-spk { display:flex; align-items:center; gap:8px; }
.iv-spk .nm { font-size:11px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; }
.iv-spk .nm.ai { color:var(--brand-accent); }
.iv-spk .nm.resp { color:var(--text-tertiary); }
.iv-spk .ts { font-family:var(--font-mono); font-size:10px; color:var(--text-tertiary); }
.iv-said { font-size:var(--text-base); line-height:1.5; color:var(--text-primary); }
.iv-said.q { color:var(--text-primary); }
.iv-said .mark-src { background:color-mix(in oklab, var(--scope-variant-fg) 16%, transparent);
  border-bottom:1.5px solid var(--scope-variant-fg); border-radius:2px; padding:0 2px; }
.iv-caret { display:inline-block; width:7px; height:15px; background:var(--brand-accent); margin-left:2px;
  vertical-align:-2px; animation:caret 1s steps(1) infinite; }
@keyframes caret { 50% { opacity:0; } }
@media (prefers-reduced-motion: reduce) { .iv-caret { animation:none; } }

.iv-right { display:flex; flex-direction:column; background:var(--bg-subtle); }
.iv-rhead { display:flex; align-items:center; gap:8px; padding:13px 16px; border-bottom:1px solid var(--border-subtle); }
.iv-rhead .ct { font-family:var(--font-mono); font-size:11px; color:var(--text-tertiary); margin-left:auto; }
.iv-items { padding:14px 16px; display:flex; flex-direction:column; gap:10px; }
.iv-item { background:var(--bg-surface); border:1px solid var(--border-default); border-radius:var(--radius-md);
  border-left:3px solid var(--finding-pain-fg); padding:11px 12px; }
.iv-item.req { border-left-color:var(--finding-requirement-fg); }
.iv-item.q   { border-left-color:var(--finding-question-fg); }
.iv-item .row1 { display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.iv-item .txt { font-size:var(--text-sm); line-height:1.4; margin-top:8px; color:var(--text-primary); }
.iv-item .acts { display:flex; align-items:center; gap:6px; margin-top:10px; }
.iv-act { font-size:11px; font-weight:600; padding:3px 9px; border-radius:var(--radius-sm); cursor:default; }
.iv-act.ok { color:var(--status-locked-fg); background:var(--status-locked-bg); }
.iv-act.no { color:var(--text-secondary); background:var(--bg-subtle); border:1px solid var(--border-subtle); }
.iv-newflag { display:inline-flex; align-items:center; gap:5px; font-size:10px; font-weight:600;
  color:var(--brand-accent); background:var(--brand-accent-tint); border-radius:99px; padding:2px 7px; }

@media (max-width:680px) {
  .iv-grid { grid-template-columns:1fr; }
  .iv-left { border-right:none; border-bottom:1px solid var(--border-subtle); }

  /* hero process model on phones: tighten the canvas and drop the desktop-only
     zoom chrome (it can't be used by touch and collided with the hint text) */
  .pm-canvas { padding:18px 12px 14px; min-height:0; }
  .pm-toolbar { gap:8px; padding:10px 12px; }
  .zoomcluster, .zoom-pct { display:none; }
  .pm-hint { position:static; display:block; margin-top:14px; white-space:normal; }
}
