/* Lab Knowledge — Explorer + Network (v2.1). Theme-aware via design tokens. */

/* layout: main + AI assist column */
.kb-head{display:flex;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap}
.kb-tabs{display:flex;gap:4px;background:var(--n-surface-2);padding:4px;border-radius:11px;border:1px solid var(--n-line)}
.kb-tab{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:560;color:var(--n-text-3);padding:7px 13px;border-radius:8px;cursor:pointer;border:1px solid transparent}
.kb-tab.on{background:var(--n-elevated);color:var(--n-text)}
.kb-tab.network.on{border-color:oklch(from var(--accent-500) l c h/.4);background:linear-gradient(180deg,oklch(from var(--accent-500) l c h/.16),oklch(from var(--accent-500) l c h/.04))}
.kb-tab .pro-badge{font-family:var(--font-mono);font-size:8px;font-weight:700;letter-spacing:.05em;color:var(--accent-300);border:1px solid oklch(from var(--accent-500) l c h/.45);border-radius:999px;padding:1px 4px}
.kb-tab.locked{opacity:.7}
.kb-body{display:grid;grid-template-columns:1fr 300px;gap:16px;align-items:start}
.kb-ai{position:sticky;top:0;background:var(--n-surface);border:1px solid var(--n-line);border-radius:var(--radius-lg);padding:14px}
@media(max-width:1100px){.kb-body{grid-template-columns:1fr}.kb-ai{position:static}}

/* governance strip */
.kb-gov{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--n-text-2);background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:var(--radius-md);padding:7px 12px;margin-bottom:14px}
.kb-gov .g{display:inline-flex;align-items:center;gap:6px}.kb-gov .g b{color:var(--n-text)}
.kb-gov .sep{width:1px;height:12px;background:var(--n-line)}
.kb-pill{font-size:9.5px;font-family:var(--font-mono);padding:2px 7px;border-radius:999px;border:1px solid var(--n-line);color:var(--n-text-3)}
.kb-pill.ok{color:var(--success);border-color:oklch(from var(--success) l c h/.4)}
.kb-pill.lock{color:var(--warning);border-color:oklch(from var(--warning) l c h/.4)}

/* explorer */
.kb-tb{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.kb-seg{display:flex;background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:9px;padding:3px}
.kb-seg button{font:inherit;font-size:12.5px;color:var(--n-text-3);background:transparent;border:0;padding:6px 11px;border-radius:6px;cursor:pointer}
.kb-seg button.on{background:var(--n-elevated);color:var(--n-text)}
.kb-files{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}
.kb-file{background:var(--n-surface);border:1px solid var(--n-line);border-radius:var(--radius-lg);padding:13px 14px;position:relative}
.kb-file:hover{border-color:oklch(from var(--accent-500) l c h/.35)}
.kb-ftop{display:flex;align-items:center;gap:7px;margin-bottom:8px;flex-wrap:wrap}
.kb-src{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-family:var(--font-mono);color:var(--n-text-3);padding:2px 6px 2px 4px;border-radius:999px;border:1px solid var(--n-line)}
.kb-srcic{width:15px;height:15px;border-radius:4px;display:inline-grid;place-items:center;flex-shrink:0;font-size:10px}
.kb-srcic.woodle{background:oklch(from var(--accent-500) l c h/.18)}
.kb-srcic.gdrive{background:oklch(.80 .13 85/.18);color:var(--warning)}
.kb-srcic.shared{background:oklch(.72 .15 155/.18);color:var(--success)}
.kb-scope{font-size:9px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:999px;border:1px solid var(--n-line);color:var(--n-text-3)}
.kb-scope.lab{color:var(--accent-300);border-color:oklch(from var(--accent-500) l c h/.35)}
.kb-scope.org{color:var(--info);border-color:oklch(from var(--info) l c h/.4)}
.kb-scope.ext{color:var(--success);border-color:oklch(from var(--success) l c h/.35)}
.kb-aiflag{font-size:9px;font-family:var(--font-mono);padding:2px 6px;border-radius:999px;color:var(--danger);border:1px solid oklch(from var(--danger) l c h/.4)}
.kb-file .yr{margin-left:auto;font-size:10.5px;color:var(--n-text-3);font-family:var(--font-mono)}
.kb-file h3{font-size:13.5px;margin:0 0 4px;line-height:1.3;color:var(--n-text)}
.kb-auth{font-size:11px;color:var(--n-text-3);margin-bottom:9px}
.kb-tagrow{display:flex;gap:5px;flex-wrap:wrap;align-items:center}
.kb-tag{font-size:10px;padding:2px 7px;border-radius:999px;border:1px solid var(--n-line);color:var(--n-text-2);background:var(--n-surface-2)}
.kb-tag.ptag{border-color:oklch(from var(--accent-500) l c h/.45);color:var(--accent-300);background:oklch(from var(--accent-500) l c h/.10)}
.kb-lockic{font-size:10px;color:var(--n-text-3)}
.kb-noteprev{margin-top:9px;font-size:11px;color:var(--n-text-2);background:var(--n-surface-2);border-left:2px solid var(--accent-500);border-radius:6px;padding:6px 9px}
.kb-privc{font-size:9px;font-family:var(--font-mono);color:var(--accent-300);margin-top:6px;display:inline-flex;align-items:center;gap:4px}
.kb-notebtn{margin-top:8px;font-size:10.5px;color:var(--accent-400);cursor:pointer;display:inline-flex;align-items:center;gap:4px}
.kb-notebtn.dis{color:var(--n-text-3);cursor:not-allowed}
.kb-gh{font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--accent-400);margin:18px 0 9px;display:flex;align-items:center;gap:8px}
.kb-gh::after{content:"";flex:1;height:1px;background:var(--n-line)}

/* network */
.kb-dials{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.kb-dial{display:flex;align-items:center;gap:6px;background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:9px;padding:4px 4px 4px 9px}
.kb-dial label{font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;color:var(--n-text-3)}
.kb-dial select{font:inherit;font-size:12px;background:var(--n-elevated);border:1px solid var(--n-line);color:var(--n-text);padding:5px 7px;border-radius:6px;cursor:pointer}
.kb-toggle{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--n-text-2);background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:9px;padding:7px 10px;cursor:pointer}
.kb-toggle.on{border-color:oklch(from var(--accent-500) l c h/.5);color:var(--accent-300)}
.kb-time{display:flex;align-items:center;gap:9px;margin-bottom:8px;font-size:11px;color:var(--n-text-3);font-family:var(--font-mono)}
.kb-time input{flex:1;accent-color:var(--accent-500)}
.kb-graph{background:radial-gradient(120% 90% at 50% 0%,oklch(from var(--accent-500) l c h/.06),transparent 60%),var(--n-surface);border:1px solid var(--n-line);border-radius:var(--radius-xl);overflow:hidden;position:relative}
.kb-nlbl{font-size:9px;fill:var(--n-text-3);font-family:var(--font-sans);pointer-events:none}
.kb-nlbl.big{font-size:11px;fill:var(--n-text);font-weight:600}
.kb-gnode{cursor:pointer;transition:opacity .12s}.kb-gedge{transition:opacity .12s}
.kb-basemap{fill:oklch(from var(--n-text) l c h/.05);stroke:oklch(from var(--n-text) l c h/.12);stroke-width:.6}
.kb-grat{stroke:oklch(from var(--n-text) l c h/.05);stroke-width:.5}
.kb-leg{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;font-size:11px;color:var(--n-text-3)}
.kb-leg .li{display:inline-flex;align-items:center;gap:5px}
.kb-dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.kb-bridge{display:inline-flex;align-items:center;gap:5px;color:var(--n-text-3)}
.kb-bridge i{width:16px;height:0;border-top:2px solid var(--accent-400);display:inline-block;border-radius:2px}

/* node drawer */
.kb-drawer{position:absolute;left:14px;bottom:14px;width:268px;background:var(--n-elevated);border:1px solid var(--n-line-2);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow-lg);display:none;z-index:8}
.kb-drawer.on{display:block}
.kb-drawer .dt{font-size:13px;font-weight:640;color:var(--n-text);margin-bottom:2px}
.kb-drawer .dm{font-size:10.5px;color:var(--n-text-3);font-family:var(--font-mono);margin-bottom:10px}
.kb-drawer .row{display:flex;justify-content:space-between;gap:10px;font-size:11.5px;padding:5px 0;border-top:1px solid var(--n-line)}
.kb-drawer .row .k{color:var(--n-text-3)}.kb-drawer .row .v{color:var(--n-text);text-align:right}
.kb-drawer .x{position:absolute;top:9px;right:11px;cursor:pointer;color:var(--n-text-3)}
.kb-drawer .note{margin-top:9px;font-size:11px;color:var(--n-text-2);background:var(--n-surface-2);border-left:2px solid var(--accent-500);border-radius:6px;padding:7px 9px}

/* premium locked */
.kb-locked{max-width:420px;margin:42px auto;text-align:center;background:var(--n-surface);border:1px solid oklch(from var(--accent-500) l c h/.3);border-radius:var(--radius-xl);padding:30px 26px}
.kb-locked .lt{font-size:16px;font-weight:660;color:var(--n-text);margin:12px 0 5px}
.kb-locked .ld{font-size:12.5px;color:var(--n-text-3);line-height:1.5;margin-bottom:16px}

/* AI assist panel */
.kb-aih{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:640;color:var(--n-text);margin-bottom:3px}
.kb-aidesc{font-size:11.5px;color:var(--n-text-3);line-height:1.45;margin-bottom:13px}
.kb-chip{display:block;width:100%;text-align:left;font:inherit;font-size:12px;color:var(--n-text);background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:9px;padding:9px 11px;margin-bottom:7px;cursor:pointer;line-height:1.35}
.kb-chip:hover{border-color:oklch(from var(--accent-500) l c h/.4);background:var(--n-elevated)}
.kb-chip .k{font-size:10px;color:var(--accent-400);font-family:var(--font-mono);display:block;margin-bottom:2px}
.kb-psec{font-size:10.5px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--n-text-3);margin:16px 0 9px}
.kb-sug{display:flex;align-items:center;gap:8px;background:var(--n-surface-2);border:1px solid var(--n-line);border-radius:9px;padding:8px 10px;margin-bottom:7px;font-size:12px;color:var(--n-text-2)}
.kb-sug .add{margin-left:auto;font-size:11px;color:var(--accent-400);cursor:pointer;border:1px solid oklch(from var(--accent-500) l c h/.4);border-radius:7px;padding:2px 8px;background:oklch(from var(--accent-500) l c h/.1)}
.kb-sug .from{font-size:9.5px;color:var(--n-text-3);font-family:var(--font-mono)}

/* note modal */
.kb-scrim{position:fixed;inset:0;background:oklch(0 0 0/.55);display:none;align-items:center;justify-content:center;z-index:200}
.kb-scrim.on{display:flex}
.kb-modal{width:560px;max-width:92vw;background:var(--n-surface);border:1px solid var(--n-line-2);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden}
.kb-modal .mh{padding:16px 18px;border-bottom:1px solid var(--n-line)}
.kb-modal .mh .t{font-size:13px;font-weight:640;color:var(--n-text)}.kb-modal .mh .s{font-size:11px;color:var(--n-text-3);margin-top:2px}
.kb-modal .mb{padding:16px 18px}
.kb-modal textarea{width:100%;min-height:104px;resize:vertical;background:var(--n-bg);border:1px solid var(--n-line);border-radius:var(--radius-md);color:var(--n-text);font:inherit;font-size:13px;line-height:1.5;padding:11px 12px;outline:none}
.kb-modal textarea:focus{border-color:oklch(from var(--accent-500) l c h/.5);box-shadow:var(--glow)}
.kb-sugbar{margin-top:12px;min-height:30px}
.kb-sugbar .lbl{font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.07em;color:var(--n-text-3);display:flex;align-items:center;gap:6px;margin-bottom:8px}
.kb-sugchips{display:flex;gap:7px;flex-wrap:wrap}
.kb-sugchip{display:inline-flex;align-items:center;gap:7px;font-size:12px;background:oklch(from var(--accent-500) l c h/.1);border:1px solid oklch(from var(--accent-500) l c h/.4);color:var(--accent-300);border-radius:999px;padding:4px 10px;cursor:pointer}
.kb-sugchip .why{font-size:9px;color:var(--n-text-3);font-family:var(--font-mono)}
.kb-sugchip.added{background:var(--n-surface-2);border-color:var(--n-line);color:var(--n-text-3);cursor:default}
.kb-attached{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
.kb-modal .mf{display:flex;align-items:center;gap:10px;padding:14px 18px;border-top:1px solid var(--n-line)}
.kb-hint{font-size:11px;color:var(--n-text-3)}
