/* IRS Audit Intelligence Layer — prototype design system (federal) */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0}
:root{
  --navy-900:#001233; --navy-800:#001a45; --navy-700:#002868; --navy-600:#0b3a86; --navy-500:#1f56ad;
  --red-700:#9b0825; --red-600:#bf0a30; --red-500:#d92344;
  --ink:#0b1524; --slate-700:#28354a; --slate-600:#3d4c66; --slate-500:#566379; --slate-400:#7d8aa1; --slate-300:#aab4c5;
  --line:#e6eaf1; --line-2:#eef1f7; --surface:#f5f8fd; --surface-2:#eaf1fb; --white:#fff;
  --green-600:#1f8a4c; --green-700:#15663a; --green-50:#e9f6ee;
  --amber-600:#b07514; --amber-700:#8a5a0f; --amber-50:#fbf2df;
  --rose-600:#bf0a30; --rose-700:#8f1228; --rose-50:#fdecef;
  --blue-50:#eaf2fd; --blue-700:#0c447c;
  --sh-1:0 1px 2px rgba(8,15,30,.07),0 1px 1px rgba(8,15,30,.04);
  --sh-2:0 6px 20px rgba(8,15,30,.09);
  --sh-3:0 18px 50px rgba(8,15,30,.22);
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --rail:336px; --side:266px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
body{font-family:var(--font);color:var(--ink);background:var(--surface);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
p{margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:#c9dcff}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:#cdd6e4;border-radius:20px;border:2px solid transparent;background-clip:content-box}
*::-webkit-scrollbar-thumb:hover{background:#b3bfd2;background-clip:content-box}

/* classification strip */
.classbar{height:26px;background:var(--navy-900);color:#cfe0ff;display:flex;align-items:center;justify-content:center;gap:10px;font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase}
.classbar .dot{width:6px;height:6px;border-radius:50%;background:var(--red-500)}
.classbar b{color:#fff;font-weight:600}

/* shell */
.app{display:grid;grid-template-columns:var(--side) 1fr;min-height:calc(100vh - 26px)}

/* sidebar */
.sidebar{background:var(--navy-800);color:#cdd9ee;display:flex;flex-direction:column;position:sticky;top:0;height:calc(100vh - 26px);border-right:1px solid #00102e}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px}
.seal{width:38px;height:38px;flex:0 0 38px}
.brand .bt{font-size:14.5px;font-weight:600;color:#fff;letter-spacing:-.01em;line-height:1.15}
.brand .bs{font-size:11px;color:#7f95bd;letter-spacing:.04em}
.prof{margin:4px 14px 12px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:11px 12px;display:flex;gap:10px;align-items:center}
.avatar{width:36px;height:36px;flex:0 0 36px;border-radius:50%;background:var(--red-600);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;letter-spacing:.02em}
.prof .pn{color:#fff;font-weight:600;font-size:13px;line-height:1.2}
.prof .pg{color:#94a8cd;font-size:11.5px}
.gradechip{display:inline-block;margin-top:3px;font-size:10.5px;font-weight:600;letter-spacing:.04em;color:#bcd0f2;background:rgba(255,255,255,.08);padding:2px 7px;border-radius:20px}
.sectlabel{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:#6f86b0;padding:14px 20px 7px;font-weight:600}
.nav{display:flex;flex-direction:column;gap:1px;padding:0 10px;overflow-y:auto}
.navitem{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:#bccbe6;cursor:pointer;font-size:13px;font-weight:500;border:1px solid transparent;transition:background .12s,color .12s}
.navitem:hover{background:rgba(255,255,255,.06);color:#fff}
.navitem.on{background:var(--white);color:var(--navy-700);font-weight:600;box-shadow:var(--sh-1)}
.navitem.on .ph-n{background:var(--red-600);color:#fff}
.navitem .ph-n{width:22px;height:22px;flex:0 0 22px;border-radius:7px;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600}
.navitem .ic{width:18px;text-align:center;font-size:15px;opacity:.85}
.navitem .nlab{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.navitem .ndot{width:6px;height:6px;border-radius:50%;background:var(--red-500)}
.side-foot{margin-top:auto;padding:14px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:#7f95bd;display:flex;align-items:center;justify-content:space-between}
.side-foot .ok{color:#7fd1a3}

/* main */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{height:62px;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(6px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 22px;position:sticky;top:0;z-index:20}
.crumb{font-size:12px;color:var(--slate-400);font-weight:500}
.crumb b{color:var(--ink);font-weight:600}
.topbar .tt{font-size:15px;font-weight:600;letter-spacing:-.01em}
.search{flex:1;max-width:420px;display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:8px 11px;color:var(--slate-400);font-size:13px;transition:border-color .12s,box-shadow .12s}
.search:focus-within{border-color:var(--navy-500);box-shadow:0 0 0 3px #d6e3ff}
.search input{border:none;background:none;outline:none;flex:1;font-family:inherit;font-size:13px;color:var(--ink)}
.spacer{flex:1}
.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:var(--white);color:var(--slate-700);padding:8px 13px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,transform .06s}
.btn:hover{background:var(--surface);border-color:var(--slate-300)}
.btn:active{transform:scale(.98)}
.btn-primary{background:var(--red-600);border-color:var(--red-600);color:#fff}
.btn-primary:hover{background:var(--red-700);border-color:var(--red-700)}
.btn-navy{background:var(--navy-700);border-color:var(--navy-700);color:#fff}
.btn-navy:hover{background:var(--navy-600)}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--white);color:var(--slate-500);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:17px;position:relative}
.icon-btn:hover{background:var(--surface);color:var(--ink)}
.icon-btn .nb{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--red-600);border:1.5px solid #fff}

/* phase stepper */
.stepper{display:flex;align-items:stretch;gap:0;padding:14px 22px 0;background:var(--white);border-bottom:1px solid var(--line)}
.step{flex:1;display:flex;flex-direction:column;gap:7px;padding-bottom:14px;cursor:pointer;position:relative}
.step .srow{display:flex;align-items:center;gap:9px}
.step .sdisc{width:26px;height:26px;flex:0 0 26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;background:var(--surface-2);color:var(--slate-500);border:1.5px solid var(--line);z-index:2}
.step .stext{font-size:12.5px;font-weight:600;color:var(--slate-500);line-height:1.2}
.step .scite{font-size:10.5px;color:var(--slate-400);font-family:var(--mono);letter-spacing:-.02em}
.step .sline{position:absolute;left:13px;right:-50%;top:13px;height:2px;background:var(--line);z-index:1}
.step:last-child .sline{display:none}
.step.done .sdisc{background:var(--navy-700);border-color:var(--navy-700);color:#fff}
.step.done .sline{background:var(--navy-700)}
.step.on .sdisc{background:var(--red-600);border-color:var(--red-600);color:#fff;box-shadow:0 0 0 4px var(--rose-50)}
.step.on .stext{color:var(--ink)}
.step.on::after{content:"";position:absolute;left:0;right:8px;bottom:-1px;height:3px;background:var(--red-600);border-radius:3px 3px 0 0}
.step:hover .sdisc{border-color:var(--navy-500)}

/* content layout */
.work{display:grid;grid-template-columns:minmax(0,1fr) var(--rail);gap:0;flex:1;min-height:0}
.canvas{padding:22px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}
.rail{border-left:1px solid var(--line);background:var(--white);padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}

/* guardrail rail (4.10.1) */
.guard{display:flex;align-items:center;gap:12px;background:linear-gradient(0deg,var(--white),var(--white));border:1px solid var(--line);border-left:3px solid var(--navy-700);border-radius:var(--r);padding:11px 14px}
.guard .gi{color:var(--navy-700);font-size:18px}
.guard .gt{font-size:12.5px;font-weight:600;color:var(--slate-700)}
.guard .gs{font-size:11.5px;color:var(--slate-500)}
.guard .gcite{margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--slate-400);background:var(--surface);padding:3px 8px;border-radius:6px}

/* metric tiles */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.tile{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px;box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
.tile .tl{font-size:11.5px;color:var(--slate-500);font-weight:500;letter-spacing:.01em;display:flex;align-items:center;gap:6px}
.tile .tv{font-size:25px;font-weight:700;letter-spacing:-.02em;line-height:1}
.tile .td{font-size:11.5px;font-weight:600;display:flex;align-items:center;gap:4px}
.tile .td.up{color:var(--green-600)} .tile .td.dn{color:var(--rose-600)}
.tile .spark{position:absolute;right:14px;top:14px;opacity:.9}
.tile.accent{background:var(--navy-700);border-color:var(--navy-700)}
.tile.accent .tl{color:#9fb6dd} .tile.accent .tv{color:#fff} .tile.accent .td{color:#ffc7d2}

/* section headers */
.sec{display:flex;align-items:center;gap:10px;margin:2px 0 -4px}
.sec h3{font-size:15px}
.sec .cite{font-family:var(--mono);font-size:11px;color:var(--slate-400);background:var(--white);border:1px solid var(--line);padding:2px 8px;border-radius:7px}
.sec .count{font-size:11.5px;color:var(--slate-400);margin-left:auto}

/* substep checklist */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:10px}
.substep{display:flex;align-items:center;gap:10px;background:var(--white);border:1px solid var(--line);border-radius:var(--r);padding:10px 12px;font-size:12.5px;color:var(--slate-700);box-shadow:var(--sh-1)}
.substep .sc{width:20px;height:20px;flex:0 0 20px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px}
.substep.ok .sc{background:var(--green-50);color:var(--green-600)}
.substep.now .sc{background:var(--rose-50);color:var(--rose-600)}
.substep.todo .sc{background:var(--surface-2);color:var(--slate-400)}
.substep .scite{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--slate-400)}

/* tool cards */
.tools{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:14px}
.toolcard{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;cursor:pointer;display:flex;flex-direction:column;gap:10px;box-shadow:var(--sh-1);transition:transform .12s,box-shadow .12s,border-color .12s;position:relative}
.toolcard:hover{transform:translateY(-2px);box-shadow:var(--sh-2);border-color:var(--slate-300)}
.toolcard .ti2{width:38px;height:38px;border-radius:11px;background:var(--surface-2);color:var(--navy-700);display:flex;align-items:center;justify-content:center;font-size:19px}
.toolcard .tn{font-size:13.5px;font-weight:600;letter-spacing:-.01em;line-height:1.25}
.toolcard .tdsc{font-size:12px;color:var(--slate-500);line-height:1.45}
.toolcard .trow{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:auto}
.toolcard .sug{position:absolute;top:12px;right:12px;font-size:10px;font-weight:700;letter-spacing:.04em;color:var(--blue-700);background:var(--blue-50);padding:3px 7px;border-radius:20px}

/* chips */
.chip{font-size:10.5px;font-weight:600;letter-spacing:.02em;padding:3px 8px;border-radius:20px;display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.chip.s-high{background:var(--rose-50);color:var(--rose-700)}
.chip.s-med{background:var(--amber-50);color:var(--amber-700)}
.chip.s-low{background:var(--green-50);color:var(--green-700)}
.chip.ghost{background:var(--surface);color:var(--slate-500);border:1px solid var(--line)}
.chip.navy{background:var(--surface-2);color:var(--navy-600)}
.chip.flag{background:var(--rose-50);color:var(--rose-700)}

/* card generic */
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1)}
.card.pad{padding:16px}

/* charts row */
.charts{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:14px}
.chart{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px;box-shadow:var(--sh-1);display:flex;flex-direction:column;gap:12px;min-width:0}
.chart h4{font-size:13px;color:var(--slate-700)}
.chart .csub{font-size:11px;color:var(--slate-400);font-weight:500}
.bar-row{display:flex;align-items:center;gap:10px;font-size:11.5px}
.bar-row .blab{width:84px;flex:0 0 84px;color:var(--slate-600);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bar-track{flex:1;height:9px;background:var(--surface-2);border-radius:20px;overflow:hidden}
.bar-fill{height:100%;border-radius:20px}
.bar-row .bval{width:42px;text-align:right;font-weight:600;color:var(--slate-700);font-variant-numeric:tabular-nums}

/* case file rail */
.casefile .cf-head{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.cf-emblem{width:42px;height:42px;flex:0 0 42px;border-radius:11px;background:var(--navy-700);color:#fff;display:flex;align-items:center;justify-content:center;font-size:19px}
.cf-name{font-size:14px;font-weight:600}
.cf-meta{font-size:11.5px;color:var(--slate-500);font-family:var(--mono)}
.kv{display:flex;justify-content:space-between;gap:10px;padding:7px 0;border-top:1px solid var(--line-2);font-size:12px}
.kv .k{color:var(--slate-500)} .kv .v{color:var(--slate-700);font-weight:600;text-align:right}
.flagwrap{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}

/* artifact / output */
.artifact{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--white)}
.artifact .ah{background:var(--surface);border-bottom:1px solid var(--line);padding:9px 12px;display:flex;align-items:center;gap:8px;font-size:11.5px;font-weight:600;color:var(--slate-600)}
.artifact .ah .live{margin-left:auto;font-size:10px;color:var(--green-700);background:var(--green-50);padding:2px 7px;border-radius:20px;font-weight:700;letter-spacing:.03em}
.artifact .ab{padding:13px;font-size:12.5px;color:var(--slate-700);line-height:1.55}
.artifact .ab .big{font-size:22px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.artifact .ab .note{margin-top:9px;font-size:10.5px;color:var(--slate-400)}
.empty{border:1.5px dashed var(--line);border-radius:var(--r);padding:22px 16px;text-align:center;color:var(--slate-400);font-size:12.5px}
.empty .ei{font-size:26px;color:var(--slate-300);margin-bottom:6px}

/* drawer */
.scrim{position:fixed;inset:0;background:rgba(6,12,26,.42);opacity:0;pointer-events:none;transition:opacity .2s;z-index:60}
.scrim.show{opacity:1;pointer-events:auto}
.drawer{position:fixed;top:0;right:0;height:100vh;width:460px;max-width:92vw;background:var(--white);box-shadow:var(--sh-3);transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1);z-index:61;display:flex;flex-direction:column}
.drawer.show{transform:none}
.dh{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;gap:13px;align-items:flex-start}
.dh .dic{width:44px;height:44px;flex:0 0 44px;border-radius:12px;background:var(--surface-2);color:var(--navy-700);display:flex;align-items:center;justify-content:center;font-size:22px}
.dh .dt{font-size:16px;font-weight:600;letter-spacing:-.01em}
.dh .dx{margin-left:auto;cursor:pointer;color:var(--slate-400);font-size:20px;background:none;border:none}
.db{padding:18px 20px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:16px}
.dgroup .dgl{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--slate-400);font-weight:600;margin-bottom:6px}
.dgroup .dgv{font-size:13px;color:var(--slate-700);line-height:1.55}
.io{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.io .iob{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:10px 12px}
.io .iob .h{font-size:10.5px;font-weight:600;color:var(--slate-500);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.io .iob ul{margin:0;padding-left:15px;font-size:12px;color:var(--slate-700)}
.io .iob li{margin:2px 0}
.df{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:10px}
.df .btn{flex:1;justify-content:center}
.cite-line{font-family:var(--mono);font-size:11.5px;color:var(--navy-600);background:var(--surface-2);border-radius:6px;padding:3px 7px;display:inline-block}
.unv{font-size:10px;color:var(--amber-700);background:var(--amber-50);padding:2px 6px;border-radius:5px;font-weight:600;margin-left:6px}

/* misc */
.muted{color:var(--slate-500)}
.divline{height:1px;background:var(--line);margin:2px 0}
@media (max-width:1180px){
  .tiles{grid-template-columns:repeat(2,1fr)} .charts{grid-template-columns:1fr}
  .work{grid-template-columns:1fr} .rail{border-left:none;border-top:1px solid var(--line)}
}
@media (max-width:880px){ .app{grid-template-columns:1fr} .sidebar{display:none} }

/* ===== Auditor's Toolkit v2.1 — toolkit-first components ===== */
.divsw{display:flex;gap:4px;margin:0 14px 6px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:4px}
.divsw button{flex:1;border:none;background:none;color:#9fb6dd;font-family:inherit;font-size:11px;font-weight:600;padding:6px 3px;border-radius:7px;cursor:pointer}
.divsw button.on{background:#fff;color:var(--navy-700)}
.qlinks{display:flex;flex-direction:column;gap:1px;padding:0 10px}
.qlink{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;color:#bccbe6;font-size:12.5px;font-weight:500;cursor:pointer;border:1px solid transparent}
.qlink:hover{background:rgba(255,255,255,.06);color:#fff}
.qlink.on{background:#fff;color:var(--navy-700);font-weight:600}
.qlink .ic{width:18px;text-align:center;font-size:15px}
.qlink .qn{margin-left:auto;font-size:10.5px;color:#7f95bd;background:rgba(255,255,255,.08);padding:1px 7px;border-radius:20px}
.qlink.contribute{color:#fff;background:var(--red-600);margin-top:8px;justify-content:center;font-weight:600}
.qlink.contribute:hover{background:var(--red-700)}

.phase-desc{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--sh-1)}
.phase-desc .pdh{display:flex;align-items:center;gap:10px;margin-bottom:2px}
.phase-desc h2{font-size:18px}
.phase-desc .pcite{font-family:var(--mono);font-size:11px;color:var(--navy-600);background:var(--surface-2);padding:2px 8px;border-radius:6px}
.phase-desc p{font-size:13.5px;color:var(--slate-600);line-height:1.6;margin-top:8px;max-width:74ch}
.govnote{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--slate-500);margin-top:11px;border-top:1px solid var(--line-2);padding-top:10px}
.govnote i{color:var(--navy-700);font-size:15px}

.toolcard .cat{font-size:10px;font-weight:600;color:var(--slate-400);letter-spacing:.05em;text-transform:uppercase}
.toolcard .vd{margin-top:2px;display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--navy-600)}
.toolcard:hover .vd{color:var(--red-600)}
.vision-badge{font-size:10px;font-weight:700;color:var(--amber-700);background:var(--amber-50);padding:2px 7px;border-radius:20px}

.tdpanel{display:flex;flex-direction:column;gap:14px}
.td-top{display:flex;gap:12px;align-items:flex-start}
.td-ic{width:46px;height:46px;flex:0 0 46px;border-radius:12px;background:var(--surface-2);color:var(--navy-700);display:flex;align-items:center;justify-content:center;font-size:22px}
.td-name{font-size:16px;font-weight:600;line-height:1.2}
.td-ver{font-size:11px;color:var(--slate-400);font-family:var(--mono);margin-top:3px}
.td-sec .tdl{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-400);font-weight:600;margin-bottom:5px}
.td-sec .tdv{font-size:12.5px;color:var(--slate-700);line-height:1.55}
.td-help{background:var(--surface-2);border-radius:var(--r);padding:11px 13px;font-size:12.5px;color:var(--navy-700);font-weight:500;line-height:1.5}
.runbox{border:1px solid var(--line);border-radius:var(--r);padding:12px;background:var(--surface)}
.runbox .rl{font-size:11px;font-weight:600;color:var(--slate-600);margin-bottom:6px}
.runbox select{width:100%;margin-bottom:9px;padding:8px 10px;border:1px solid var(--line);border-radius:8px;font-family:inherit;font-size:12.5px;background:var(--white);color:var(--ink)}
.td-actions{display:flex;gap:8px}
.td-actions .btn{flex:1;justify-content:center}

.libbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:12px 14px;box-shadow:var(--sh-1)}
.libbar .lbl{font-size:11px;color:var(--slate-400);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.filtsel{padding:7px 10px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:12.5px;background:var(--white);color:var(--ink)}

.modal-wrap{position:fixed;inset:0;background:rgba(6,12,26,.42);display:flex;align-items:center;justify-content:center;padding:24px;z-index:61;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-wrap.show{opacity:1;pointer-events:auto}
.modal{background:var(--white);border-radius:var(--r-lg);box-shadow:var(--sh-3);width:580px;max-width:94vw;max-height:88vh;overflow:auto;transform:translateY(10px);transition:transform .22s}
.modal-wrap.show .modal{transform:none}
.modal .mh{padding:17px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:11px}
.modal .mh .dic{width:38px;height:38px;border-radius:10px;background:var(--surface-2);color:var(--navy-700);display:flex;align-items:center;justify-content:center;font-size:18px}
.modal .mh h3{font-size:16px}
.modal .mh .ms{font-size:11.5px;color:var(--slate-500)}
.modal .mh .dx{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--slate-400);font-size:20px}
.modal .mb{padding:18px 20px;display:flex;flex-direction:column;gap:13px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--slate-600);margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:13px;background:var(--white);color:var(--ink);outline:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #d6e3ff}
.field textarea{min-height:70px;resize:vertical}
.field2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal .mf{padding:14px 20px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:10px}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--navy-800);color:#fff;padding:11px 18px;border-radius:12px;font-size:13px;box-shadow:var(--sh-3);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:70;display:flex;align-items:center;gap:9px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast i{color:#7fd1a3;font-size:16px}

.minilist{display:flex;flex-direction:column;gap:7px}
.minirow{display:flex;align-items:center;gap:9px;padding:8px 10px;border:1px solid var(--line);border-radius:9px;cursor:pointer;font-size:12.5px;background:var(--white)}
.minirow:hover{border-color:var(--slate-300)}
.minirow .mi{width:26px;height:26px;flex:0 0 26px;border-radius:7px;background:var(--surface-2);color:var(--navy-700);display:flex;align-items:center;justify-content:center;font-size:13px}
.minirow .mt{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}

/* ===== v2.2 — rich tool-detail modal, run artifact, prioritized phase sections ===== */
.modal.wide{width:880px;max-width:95vw}
.tdgrid{display:grid;grid-template-columns:1.2fr 1fr}
.tdgrid .tl{padding:18px 20px;display:flex;flex-direction:column;gap:14px;border-right:1px solid var(--line);min-width:0}
.tdgrid .tr{padding:18px 20px;display:flex;flex-direction:column;gap:13px;background:var(--surface);min-width:0}
.tdgrid .tr .rl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-400);font-weight:600}
.tdgrid select{width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:12.5px;background:var(--white);color:var(--ink)}
.sampleline{font-size:11.5px;color:var(--slate-500);background:var(--white);border:1px solid var(--line);border-radius:8px;padding:8px 10px;line-height:1.45}

.runart{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--white)}
.runart .rah{background:var(--navy-700);color:#fff;padding:9px 12px;font-size:12px;font-weight:600;display:flex;align-items:center;gap:8px;letter-spacing:.01em}
.runart .rah .live{margin-left:auto;font-size:10px;background:rgba(255,255,255,.16);padding:2px 8px;border-radius:20px;letter-spacing:.04em}
.runart .rab{padding:13px}
.runart .rhead{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:10px;letter-spacing:-.01em;line-height:1.25}
.runkv{display:flex;justify-content:space-between;gap:12px;padding:6px 0;border-top:1px solid var(--line-2);font-size:12.5px}
.runkv:first-of-type{border-top:none}
.runkv .k{color:var(--slate-500)} .runkv .v{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums;text-align:right}
.runart .rnote{margin-top:11px;font-size:11px;color:var(--slate-400);line-height:1.5;border-top:1px solid var(--line-2);padding-top:9px}
.runempty{border:1.5px dashed var(--line);border-radius:var(--r);padding:20px 14px;text-align:center;color:var(--slate-400);font-size:12.5px;background:var(--white)}
.runempty .ei{font-size:24px;color:var(--slate-300);margin-bottom:6px}

.secline{display:flex;align-items:center;gap:9px;margin:8px 0 -2px}
.secline h3{font-size:14px}
.secline .sb{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:20px}
.secline .sb.prim{background:var(--rose-50);color:var(--rose-700)}
.secline .sb.also{background:var(--surface-2);color:var(--navy-600)}
.secline .count{margin-left:auto;font-size:11.5px;color:var(--slate-400)}
.toolcard.primary{border-color:#d9e2f0}
.toolcard.primary .ti2{background:var(--navy-700);color:#fff}
.yrs{font-size:10.5px;color:#94a8cd}

@media (max-width:760px){ .tdgrid{grid-template-columns:1fr} .tdgrid .tl{border-right:none;border-bottom:1px solid var(--line)} }

/* ===== v2.3 — repository portal (function selector, download) ===== */
.portalsel{width:calc(100% - 28px);margin:0 14px 6px;padding:8px 10px;border-radius:9px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:#e7eefb;font-family:inherit;font-size:12px;font-weight:500;cursor:pointer}
.portalsel:focus{outline:none;border-color:#3f63a8}
.portalsel option{color:#0b1524}
.dl-hint{font-size:11px;color:var(--slate-500);text-align:center;line-height:1.5}
.synthbar{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--amber-700);background:var(--amber-50);border:1px solid #f0dcb0;border-radius:8px;padding:7px 10px;font-weight:600}
