/* lab-engine.css, shared styles for all interactive labs.
   A lab = this CSS + lab-engine.js + a LAB config object. */
:root{
  --bg:#faf9f7; --card:#fff; --line:#e9e7e4; --ink:#1a1a1f; --body:#3f3f46; --mut:#8a8a93; --dim:#a8a8af;
  --brand:#7c3aed; --brand-dark:#6d28d9; --brand-bg:#f4efff; --badge-bg:#ede9fe; --badge-fg:#6d28d9;
  --ok:#1f7a44; --ok-bg:#eafaf0; --okline:#bfe3cc; --bad:#b3402f; --bad-bg:#fbe9e6; --badline:#f0c4bc;
  --amber:#9a6a00; --amber-bg:#fbf4df;
  --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--body);font-family:var(--font);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:var(--brand);text-decoration:none}
.wrap{max-width:760px;margin:0 auto;padding:0 24px}
.bar{background:#fffffff2;backdrop-filter:blur(8px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.bar .in{max-width:760px;margin:0 auto;padding:0 24px;height:58px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:700;color:var(--ink)}
.logo .b{color:var(--brand)}
.back{font-size:13.5px;color:var(--mut);font-weight:500} .back:hover{color:var(--ink)}

.hero{text-align:center;padding:40px 0 8px}
.hero h1{font-size:28px;letter-spacing:-.5px;color:var(--ink);font-weight:800;margin:0 0 6px}
.hero p{color:var(--mut);font-size:15px;margin:0 auto;max-width:560px}

.progress{display:flex;gap:6px;margin:22px 0 6px}
.pdot{flex:1;height:6px;border-radius:6px;background:#e7e4ef}
.pdot.done{background:var(--brand)} .pdot.cur{background:#c3b6e6}
.pcount{font-size:12px;color:var(--mut);text-align:right;margin-bottom:14px;font-family:var(--mono)}

.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:26px 28px;box-shadow:0 1px 3px #0000000d;margin-bottom:22px}
.phase{font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);font-weight:700}
.layer{display:inline-block;font-size:11px;font-weight:700;border-radius:20px;padding:2px 10px;margin-left:8px;vertical-align:middle}
.layer.mech{background:#eef1f5;color:#566} .layer.ai{background:var(--badge-bg);color:var(--badge-fg)} .layer.you{background:var(--ok-bg);color:var(--ok)}
h2{font-size:20px;color:var(--ink);font-weight:750;letter-spacing:-.3px;margin:6px 0 12px}
.body p{font-size:15px;margin:0 0 12px}
.body b{color:var(--ink)}
details{margin:12px 0;border:1px solid var(--line);border-radius:10px;padding:10px 14px;background:#fbfbfd}
summary{cursor:pointer;color:var(--brand);font-weight:600;font-size:13.5px}
.detail-body{margin-top:8px}
pre{font:12px/1.5 var(--mono);white-space:pre;overflow-x:auto;color:var(--ink);margin:10px 0 0}
.promptbox{position:relative;background:#f6f5f9;border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:12px 0;font:12.5px/1.6 var(--mono);white-space:pre-wrap;color:#2c2c34}
.copy{position:absolute;top:9px;right:9px;font:600 11.5px var(--font);color:var(--brand);background:#fff;border:1px solid #e0d7f7;border-radius:7px;padding:4px 10px;cursor:pointer}
.copy:hover{background:var(--brand);color:#fff}

.q{font-weight:650;color:var(--ink);font-size:15.5px;margin:16px 0 12px}
.opt{display:block;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:13px 16px;margin:0 0 9px;font:500 14.5px var(--font);color:var(--ink);cursor:pointer;transition:.12s}
.opt:hover{border-color:#c3b6e6;background:#fcfaff}
.opt.sel{border-color:var(--brand);background:var(--brand-bg)}
.opt.right{border-color:var(--okline);background:var(--ok-bg)}
.opt.wrong{border-color:var(--badline);background:var(--bad-bg)}
.opt:disabled{cursor:default}
.numrow{display:flex;gap:10px;align-items:center;margin:8px 0;flex-wrap:wrap}
input[type=text]{font:600 16px var(--mono);border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;width:200px;color:var(--ink)}
input[type=text]:focus{outline:2px solid #d9cdf5;border-color:#c3b6e6}
button.go{font:600 14px var(--font);background:var(--brand);color:#fff;border:0;border-radius:10px;padding:11px 20px;cursor:pointer}
button.go:hover{background:var(--brand-dark)}
button.ghost{font:600 13.5px var(--font);background:#f3f1ef;color:var(--ink);border:1px solid var(--line);border-radius:9px;padding:9px 15px;cursor:pointer}

.fb{border-radius:11px;padding:13px 16px;margin-top:14px;font-size:14px;display:none}
.fb.show{display:block}
.fb.good{background:var(--ok-bg);border:1px solid var(--okline);color:#16613a}
.fb.bad{background:var(--bad-bg);border:1px solid var(--badline);color:#8a3022}
.fb.hint{background:var(--amber-bg);border:1px solid #ecdcab;color:var(--amber)}
.fb b{color:inherit}
.nav{display:flex;gap:10px;align-items:center;margin-top:18px;flex-wrap:wrap}
.reveal{font-size:12.5px;color:var(--mut);cursor:pointer;text-decoration:underline}

.done h2{color:var(--brand)}
.recap{background:var(--brand-bg);border:1px solid #e6dcff;border-radius:12px;padding:16px 18px;margin:14px 0;font-size:14px}
.recap b{color:var(--brand-dark)}
.foot{text-align:center;color:var(--dim);font-size:12px;padding:6px 0 90px}
.hintlbl{font-size:11px;color:var(--dim);font-family:var(--mono)}
.mono{font-family:var(--mono);font-size:.92em}

/* terminal / code */
.codeblk{background:#f6f5f9;border:1px solid var(--line);border-radius:10px;padding:14px 16px;font:12px/1.7 var(--mono);white-space:pre;overflow-x:auto;color:#3a3a45;margin:8px 0}
.term{background:#0d1117;color:#c9d1d9;border-radius:10px;padding:14px 16px;font:12px/1.6 var(--mono);white-space:pre;overflow:auto;max-height:380px;margin:12px 0;display:none}
.term.show{display:block}

/* categorize / redact tables */
.catwrap{overflow-x:auto;margin:6px 0 4px;border:1px solid var(--line);border-radius:12px}
.cattbl{width:100%;border-collapse:collapse;font-size:13px}
.cattbl th{text-align:left;color:var(--mut);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:9px 10px;border-bottom:1px solid var(--line);background:#faf9fc}
.cattbl td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:top;color:var(--ink)}
.cattbl tr:last-child td{border-bottom:0}
.cattbl td.amt.cattbl th.amt{font-family:var(--mono);white-space:nowrap;text-align:right}
.catsel{font:13px var(--font);border:1.5px solid var(--line);border-radius:8px;padding:7px 9px;background:#fff;color:var(--ink);max-width:240px}
.cell.cellok .catsel{border-color:var(--okline);background:var(--ok-bg)}
.cell.cellbad .catsel{border-color:var(--badline);background:var(--bad-bg)}
.rev{font-size:12px;color:var(--amber);background:var(--amber-bg);border:1px solid #ecdcab;border-radius:7px;padding:5px 9px;margin-top:6px;max-width:360px;line-height:1.45}
.tagbtn{font:600 13px var(--font);border:1.5px solid var(--line);background:#fff;color:var(--ink);border-radius:8px;padding:7px 13px;margin-right:8px;cursor:pointer}
.tagbtn.sel{border-color:var(--brand);background:var(--brand-bg);color:var(--brand-dark)}
.cell.cellok .tagbtn.sel{border-color:var(--okline);background:var(--ok-bg);color:var(--ok)}
.cell.cellbad .tagbtn.sel{border-color:var(--badline);background:var(--bad-bg);color:var(--bad)}

/* connect AI */
.connect{border:1px dashed #d8cff2;background:#fbfaff}
.connect .row.modelpop .row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:10px}
.connect input[type=password].connect select.modelpop input[type=password].modelpop select.modelpop input[type=text]{font:13px var(--mono);border:1.5px solid var(--line);border-radius:9px;padding:9px 12px;color:var(--ink)}
.connect input[type=password].modelpop input[type=password]{flex:1;min-width:150px}
.connect .note.modelpop .note{font-size:12px;color:var(--mut);margin-top:10px}
.connect .note a.modelpop .note a{font-weight:600}
.modelpop .go.modelpop .tinybtn{flex:0 0 auto}
.mp-conn{font-size:13px;color:#16613a;background:var(--ok-bg);border:1px solid var(--okline);border-radius:10px;padding:8px 11px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.mp-list{display:flex;flex-direction:column;margin:0 -4px}
.mp-row{display:flex;align-items:center;gap:11px;padding:10px 8px;border-radius:10px;cursor:pointer}
.mp-row:hover{background:#f7f5fb}
.mp-row.sel{background:#f4efff}
.mp-dot{width:9px;height:9px;border-radius:50%;flex:0 0 9px}
.mp-meta{display:flex;flex-direction:column;line-height:1.3;flex:1;min-width:0}
.mp-meta b{font-size:14px;color:var(--ink)}
.mp-meta span{font-size:11.5px;color:var(--mut);font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mp-chk{color:var(--ok);font-weight:800;font-size:15px}
.mp-cfg{display:flex;flex-direction:column;gap:7px;padding:6px 8px 12px}
.mp-cfg input{width:100%;font:13px var(--mono);border:1.5px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--ink)}
.mp-cfg .row{display:flex;gap:8px;margin:0}
.mp-cfg .row input{flex:1}
.ok-tag{color:var(--ok);font-weight:700;font-size:13.5px}
.runai{display:inline-flex;align-items:center;gap:7px;font:600 13.5px var(--font);background:var(--brand);color:#fff;border:0;border-radius:9px;padding:10px 16px;cursor:pointer;margin:6px 0 2px}
.runai:hover{background:var(--brand-dark)} .runai:disabled{opacity:.5;cursor:default}
.airesult{background:#0f1320;color:#e6edf6;border-radius:10px;padding:14px 16px;margin:12px 0;font:12px/1.6 var(--mono);white-space:pre-wrap;max-height:340px;overflow:auto;display:none}
.airesult.show{display:block}
.tinybtn{font:600 11.5px var(--font);background:#f3f1ef;border:1px solid var(--line);border-radius:7px;padding:5px 10px;cursor:pointer;color:var(--ink)}

/* command bar, floating */
.cmdbar{position:fixed;left:0;right:0;bottom:0;z-index:6;padding:0 16px;pointer-events:none}
.cmdbar .in{position:relative;pointer-events:auto;max-width:680px;margin:0 auto 16px;background:#fffffffa;backdrop-filter:blur(12px);border:1.5px solid #d9cdf5;border-radius:16px;padding:11px 13px;
  box-shadow:0 12px 36px rgba(124,58,237.24), 0 0 0 4px rgba(124,58,237.07)}

/* model chip + popover */
.modelchip{display:inline-flex;align-items:center;gap:7px;font:600 13px var(--font);background:#f5f3ef;border:1px solid var(--line);border-radius:10px;padding:9px 12px;cursor:pointer;color:var(--ink);white-space:nowrap;flex:0 0 auto}
.modelchip:hover{background:#efeaf8;border-color:#d9cdf5}
.modelchip .dot{width:8px;height:8px;border-radius:50%;background:#bcc3cd;flex:0 0 8px}
.modelchip.on .dot{background:#28a745}
.modelchip .car{color:var(--mut);font-size:10px;margin-left:1px}
.modelpop{position:absolute;bottom:calc(100% + 10px);left:0;width:min(440px,88vw);background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 18px 44px rgba(22,38,63.22);padding:16px 18px;display:none;z-index:7}
.modelpop.show{display:block}
.modelpop .hd{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--mut);font-weight:700;margin-bottom:8px}
.chatlog{max-height:260px;overflow:auto;margin-bottom:8px;display:none}
.chatlog.show{display:block}
.msg{font-size:13.5px;line-height:1.55;margin:8px 0;padding:9px 12px;border-radius:10px;white-space:pre-wrap}
.msg.u{background:var(--brand-bg);color:var(--ink)} .msg.a{background:#f3f3f5;color:var(--ink)} .msg.sys{background:var(--amber-bg);color:var(--amber);font-size:12.5px}
.cmdrow{display:flex;gap:8px;align-items:center}
.cmdrow input{flex:1;font:14px var(--font);border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;color:var(--ink)}
.cmdrow input:focus{outline:2px solid #d9cdf5;border-color:#c3b6e6}
