/* ════════════════ AGENT DETAIL DASHBOARDS — drill-down views ════════════════ */
#detail{position:absolute;inset:0;z-index:80;display:none;opacity:0;
  background:radial-gradient(1500px at 50% 30%, #0a1322 0%, #070c16 55%, #04070d 100%);
  transform:scale(.9);transform-origin:center center;transition:opacity .42s cubic-bezier(.6,0,.2,1),transform .42s cubic-bezier(.6,0,.2,1)}
#detail.live{display:block}
#detail.shown{opacity:1;transform:scale(1)}
#detail.closing{opacity:0;transform:scale(.92)}

/* header */
#d-head{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:22px 40px 18px;background:linear-gradient(180deg,rgba(7,12,22,.96) 60%,rgba(7,12,22,0));backdrop-filter:blur(6px)}
#d-head .id{display:flex;align-items:center;gap:18px}
#d-back{font-family:var(--micro);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--reticle-dim);background:rgba(10,16,26,.6);padding:9px 15px;cursor:pointer;
  clip-path:polygon(8px 0,100% 0,100% calc(100% - 8px),calc(100% - 8px) 100%,0 100%,0 8px)}
#d-back:hover{color:var(--d-ac);border-color:var(--d-ac)}
#d-head .name{font-family:var(--display);font-weight:900;font-size:32px;letter-spacing:.16em;color:var(--d-ac);
  text-shadow:0 0 3px var(--d-ac),0 0 30px color-mix(in srgb,var(--d-ac) 30%,transparent)}
#d-head .role{font-family:var(--micro);font-size:11px;letter-spacing:.30em;text-transform:uppercase;color:var(--ink-3);margin-top:5px}
#d-head .right{display:flex;align-items:center;gap:18px;font-family:var(--mono);font-size:12px;color:var(--ink-2)}
#d-head .statuspill{display:inline-flex;align-items:center;gap:8px;font-family:var(--micro);letter-spacing:.2em;
  font-size:11px;text-transform:uppercase;color:var(--d-ac);border:1px solid var(--d-ac);padding:5px 12px;
  background:color-mix(in srgb,var(--d-ac) 8%,transparent)}
#d-head .livedot{width:7px;height:7px;border-radius:50%;background:var(--d-ac);box-shadow:0 0 10px var(--d-ac);animation:hb 1.6s ease-in-out infinite}

/* scroll body + grid */
#d-scroll{position:absolute;inset:96px 0 0 0;overflow-y:auto;overflow-x:hidden;padding:4px 40px 60px}
#d-scroll::-webkit-scrollbar{width:9px}
#d-scroll::-webkit-scrollbar-track{background:rgba(255,255,255,.02)}
#d-scroll::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--d-ac) 30%,#1a2433);border-radius:6px}
#d-scroll::-webkit-scrollbar-thumb:hover{background:var(--d-ac)}
#d-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;max-width:1840px;margin:0 auto;align-items:start}

/* panel base */
.dp{position:relative;background:var(--glass-fill);-webkit-backdrop-filter:blur(14px) saturate(116%);backdrop-filter:blur(14px) saturate(116%);
  box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--d-ac) 12%,transparent),var(--glass-litedge);
  padding:16px 18px;min-height:120px;
  clip-path:polygon(14px 0,100% 0,100% calc(100% - 14px),calc(100% - 14px) 100%,0 100%,0 14px);
  opacity:0;transform:translateY(14px);transition:opacity .5s,transform .5s}
.dp.in{opacity:1;transform:translateY(0)}
.dp::after{content:"";position:absolute;right:8px;top:8px;width:10px;height:10px;
  border-top:1px solid color-mix(in srgb,var(--d-ac) 40%,transparent);border-right:1px solid color-mix(in srgb,var(--d-ac) 40%,transparent)}
.dp .ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.dp .pt{font-family:var(--micro);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink-3)}
.dp .pmeta{font-family:var(--mono);font-size:11px;color:color-mix(in srgb,var(--d-ac) 70%,#9fc4d6);letter-spacing:.06em}

/* spans */
.w2{grid-column:span 2}.w3{grid-column:span 3}.w4{grid-column:span 4}.w5{grid-column:span 5}
.w6{grid-column:span 6}.w7{grid-column:span 7}.w8{grid-column:span 8}.w12{grid-column:span 12}

/* bignum */
.dp-bignum{display:flex;flex-direction:column;justify-content:center}
.dp-bignum .bn{font-family:var(--mono);font-weight:700;font-size:54px;color:var(--ink-1);line-height:1;
  text-shadow:0 0 3px color-mix(in srgb,var(--d-ac) 50%,transparent),0 0 26px color-mix(in srgb,var(--d-ac) 22%,transparent)}
.dp-bignum .bl{font-family:var(--micro);font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}
.dp-bignum .bd{font-family:var(--mono);font-size:13px;color:var(--ok);margin-top:6px;letter-spacing:.04em}
.dp-bignum .bd.warn{color:var(--warn)}

/* tiles */
.dp-tiles .tg{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:1px;background:rgba(57,211,255,.05)}
.dp-tiles .ti{background:var(--well);padding:13px 12px;display:flex;flex-direction:column;gap:6px}
.dp-tiles .ti .v{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--ink-1)}
.dp-tiles .ti .v.ac{color:var(--d-ac)}
.dp-tiles .ti .k{font-family:var(--micro);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.dp-tiles .ti .s{font-family:var(--mono);font-size:10px;color:var(--ink-3)}

/* charts */
.dp-chart .cv{width:100%;height:200px;overflow:visible}
.dp-chart.tall .cv{height:280px}
.gridline{stroke:rgba(120,160,200,.08);stroke-width:1}
.axlab{font-family:var(--mono);font-size:9px;fill:var(--ink-3);letter-spacing:.05em}
.cline{fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.carea{opacity:.16}
.ctip{animation:tippulse 1.6s ease-in-out infinite}
.cbar{transform-origin:bottom;transform:scaleY(0);transition:transform .7s cubic-bezier(.3,1,.4,1)}
.clegend{display:flex;gap:16px;margin-top:8px;flex-wrap:wrap}
.clegend span{font-family:var(--mono);font-size:11px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.clegend i{width:14px;height:3px;border-radius:2px;display:inline-block}

/* gauge */
.dp-gauge{display:flex;align-items:center;gap:20px}
.dp-gauge .gv{font-family:var(--mono);font-weight:700;font-size:40px;color:var(--ink-1)}
.dp-gauge .gu{font-family:var(--micro);font-size:10px;letter-spacing:.2em;color:var(--ink-3);text-transform:uppercase}

/* feed */
.dp-feed .fl{height:230px;overflow:hidden;position:relative;font-family:var(--mono);font-size:12px;line-height:1.85}
.dp-feed.short .fl{height:160px}
.dp-feed .row{display:flex;gap:10px;opacity:0;animation:feedin .4s forwards}
.dp-feed .row .ts{color:var(--ink-3);flex:0 0 auto}
.dp-feed .row .tx{color:var(--ink-2)}
.dp-feed .row .tx b{color:var(--d-ac);font-weight:400}
.dp-feed .row.ok .tx b{color:var(--ok)} .dp-feed .row.warn .tx b{color:var(--warn)}
@keyframes feedin{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* table */
.dp-table .tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12px}
.dp-table.scroll .twrap{max-height:280px;overflow-y:auto}
.dp-table th{font-family:var(--micro);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  text-align:left;padding:7px 10px;position:sticky;top:0;background:rgba(8,13,22,.96);border-bottom:1px solid rgba(57,211,255,.1)}
.dp-table td{padding:8px 10px;color:var(--ink-2);border-bottom:1px solid rgba(120,160,200,.05)}
.dp-table tr{opacity:0;animation:feedin .4s forwards}
.dp-table .dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:7px}
.dp-table .g{background:var(--ok);box-shadow:0 0 7px var(--ok)} .dp-table .a{background:var(--warn);box-shadow:0 0 7px var(--warn)}
.dp-table td.num{text-align:right;color:var(--ink-1)} .dp-table td.ac{color:var(--d-ac)}

/* progress */
.dp-prog .pr{margin:11px 0}
.dp-prog .pr .pl{display:flex;justify-content:space-between;font-family:var(--mono);font-size:12px;margin-bottom:5px}
.dp-prog .pr .pl .pk{color:var(--ink-2)} .dp-prog .pr .pl .pvv{color:var(--d-ac)}
.dp-prog .pr .bar{height:6px;background:var(--well);border-radius:3px;overflow:hidden}
.dp-prog .pr .bar i{display:block;height:100%;width:0;border-radius:3px;
  background:linear-gradient(90deg,color-mix(in srgb,var(--d-ac) 40%,transparent),var(--d-ac));
  box-shadow:0 0 8px color-mix(in srgb,var(--d-ac) 50%,transparent);transition:width 1s cubic-bezier(.3,1,.4,1)}

/* canvas panels (radar / nodes / heartbeat) */
.dp-canvas canvas{width:100%;display:block}
.dp-canvas.radar canvas{height:260px}
.dp-canvas.nodes canvas{height:330px}
.dp-canvas.heart canvas{height:90px}

/* ── SAARVIS liveness: every panel scans + breathes (the most-animated agent) ── */
.dp.livescan::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;z-index:3;pointer-events:none;
  background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--d-ac) 75%,transparent),transparent);
  animation:dpscan 3.6s linear infinite;animation-delay:var(--sd,0s)}
@keyframes dpscan{0%{top:0;opacity:0}10%{opacity:.7}90%{opacity:.7}100%{top:100%;opacity:0}}
.dp.livescan .pt::after{content:" \25CF";color:var(--d-ac);font-size:0.7em;animation:dpblink 1.5s steps(1) infinite}
@keyframes dpblink{0%,55%{opacity:1}56%,100%{opacity:.2}}
.livepulse{animation:livethrob 2.3s ease-in-out infinite}
@keyframes livethrob{0%,100%{text-shadow:0 0 2px color-mix(in srgb,var(--d-ac) 40%,transparent)}
  50%{text-shadow:0 0 4px var(--d-ac),0 0 24px color-mix(in srgb,var(--d-ac) 50%,transparent)}}

/* ── dense live panels: stream / matrix / monitor / scanbars ── */
.dp-stream{display:flex;flex-direction:column}
.dp-stream .streambox{overflow:hidden;font-family:var(--mono);font-size:11px;line-height:1.7;
  -webkit-mask:linear-gradient(180deg,transparent,#000 8%,#000 90%,transparent);mask:linear-gradient(180deg,transparent,#000 8%,#000 90%,transparent)}
.dp-stream .srow{display:flex;gap:9px;opacity:0;animation:feedin .35s forwards}
.dp-stream .srow .st{color:var(--ink-3);flex:0 0 auto}
.dp-stream .srow .sx{color:var(--ink-2)} .dp-stream .srow .sx b{color:var(--d-ac);font-weight:400}
.dp-stream .srow.ok .sx b{color:var(--ok)} .dp-stream .srow.warn .sx b{color:var(--warn)}
.dp-matrix .mgrid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:1px;background:rgba(57,211,255,.07)}
@media(max-width:900px){.dp-matrix .mgrid{grid-template-columns:repeat(4,minmax(0,1fr))}}
.dp-matrix .mcell{background:var(--well);padding:11px 12px;display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden}
.dp-matrix .mv{font-family:var(--mono);font-weight:700;font-size:17px;color:var(--ink-1);transition:color .3s}
.dp-matrix .mv.up{color:var(--d-ac)}
.dp-matrix .mk{font-family:var(--micro);font-size:8.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.dp-matrix .mspark{position:absolute;left:0;right:0;bottom:0;height:2px;background:linear-gradient(90deg,transparent,var(--d-ac));opacity:0;transition:opacity .3s}
.dp-matrix .mcell.flash .mspark{opacity:.7}
.dp-canvas.monitor{display:flex;flex-direction:column}
.dp-canvas.monitor canvas{width:100%;display:block}
.dp-scan .scanrow{display:grid;grid-template-columns:116px 1fr 40px;align-items:center;gap:10px;margin:10px 0;font-family:var(--mono);font-size:11px}
.dp-scan .scanrow .sl{color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dp-scan .scanrow .sbar{height:5px;background:var(--well);border-radius:3px;overflow:hidden}
.dp-scan .scanrow .sbar i{display:block;height:100%;width:0;background:linear-gradient(90deg,color-mix(in srgb,var(--d-ac) 35%,transparent),var(--d-ac));box-shadow:0 0 7px color-mix(in srgb,var(--d-ac) 45%,transparent)}
.dp-scan .scanrow .sp{color:var(--d-ac);text-align:right} .dp-scan .scanrow .sp.ok{color:var(--ok)}

/* ── role panels: summary / checklist / backlog ── */
.dp-summary{border-left:3px solid var(--d-ac)}
.dp-summary .sumhl{font-family:var(--serif,Georgia),serif;font-style:italic;font-size:19px;color:#eaf2f8;line-height:1.45;margin-bottom:13px}
.dp-summary .sumpts{list-style:none;display:flex;flex-direction:column;gap:8px}
.dp-summary .sumpts li{font-family:var(--mono);font-size:12.5px;color:var(--ink-2);padding-left:17px;position:relative;line-height:1.45}
.dp-summary .sumpts li::before{content:"\25B8";position:absolute;left:0;color:var(--d-ac)}
.dp-summary .sumpts li b{color:var(--d-ac);font-weight:400}
.dp-check .ckhdr{display:flex;align-items:baseline;gap:9px;margin-bottom:13px}
.dp-check .ckprog{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--d-ac)}
.dp-check .cklbl{font-family:var(--micro);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.dp-check .cklist{list-style:none;display:flex;flex-direction:column;gap:10px}
.dp-check .cklist li{display:flex;align-items:center;gap:11px;font-family:var(--mono);font-size:12.5px}
.dp-check .ckbox{flex:0 0 auto;width:16px;height:16px;border-radius:3px;border:1px solid var(--ink-3);position:relative;transition:all .3s}
.dp-check li.todo .ckbox{border-color:color-mix(in srgb,var(--d-ac) 55%,transparent)}
.dp-check li.done .ckbox{border-color:var(--ok);background:rgba(34,197,94,.12)}
.dp-check li.done.ticked .ckbox::after{content:"\2713";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--ok);font-size:11px}
.dp-check .cktx{color:var(--ink-2)}
.dp-check li.done .cktx{color:var(--ink-3);text-decoration:line-through;text-decoration-color:rgba(255,255,255,.18)}
.dp-check .cktag{margin-left:auto;font-family:var(--micro);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--warn);border:1px solid rgba(255,174,92,.4);padding:1px 7px;border-radius:2px}
.dp-backlog .bllist{display:flex;flex-direction:column}
.dp-backlog .blrow{display:flex;align-items:center;gap:11px;padding:9px 2px;border-bottom:1px solid rgba(120,160,200,.06)}
.dp-backlog .bldot{flex:0 0 auto;width:7px;height:7px;border-radius:50%;background:var(--d-ac);box-shadow:0 0 7px var(--d-ac)}
.dp-backlog .bldot.warn{background:var(--warn);box-shadow:0 0 7px var(--warn)}
.dp-backlog .bldot.idle{background:var(--ink-3);box-shadow:none}
.dp-backlog .blmain{flex:1;min-width:0}
.dp-backlog .blt{font-family:var(--mono);font-size:12.5px;color:var(--ink-1)}
.dp-backlog .blm{font-family:var(--mono);font-size:10.5px;color:var(--ink-3);margin-top:2px}
.dp-backlog .blstat{flex:0 0 auto;font-family:var(--micro);font-size:9px;letter-spacing:.12em;text-transform:uppercase;padding:3px 9px;border-radius:2px;color:var(--ink-3);border:1px solid var(--reticle-dim)}
.dp-backlog .blstat.go{color:var(--ok);border-color:rgba(34,197,94,.35)}
.dp-backlog .blstat.warn{color:var(--warn);border-color:rgba(255,174,92,.4)}
.dp-backlog .blstat.live{color:var(--d-ac);border-color:color-mix(in srgb,var(--d-ac) 40%,transparent)}

/* ── personal journal (diary feel, distinct from the telemetry above) ── */
.dp-journal{border-top:2px solid color-mix(in srgb,var(--d-ac) 32%,transparent);background:linear-gradient(180deg,color-mix(in srgb,var(--d-ac) 4%,transparent),transparent 60%)}
.dp-journal .jgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1000px){.dp-journal .jgrid{grid-template-columns:1fr 1fr}}
.dp-journal .jcard{border-left:2px solid color-mix(in srgb,var(--d-ac) 45%,transparent);padding:2px 0 2px 15px}
.dp-journal .jlabel{font-family:var(--micro);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--d-ac);margin-bottom:10px}
.dp-journal .jtext{font-family:var(--serif,Georgia),serif;font-style:italic;font-size:14.5px;line-height:1.55;color:#cdd9e3}
.dp-journal .jfoot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;padding-top:13px;border-top:1px solid rgba(120,160,200,.08)}
.dp-journal .jmood{font-family:var(--micro);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.dp-journal .jsign{font-family:var(--serif,Georgia),serif;font-style:italic;font-size:14px;color:var(--d-ac)}

/* hint prompt on command center */
#explore-hint{position:absolute;left:50%;bottom:96px;transform:translateX(-50%);z-index:26;
  font-family:var(--micro);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--ink-3);
  opacity:0;transition:opacity .6s;pointer-events:none}
#explore-hint.on{opacity:1;animation:hintpulse 2.6s ease-in-out infinite}
.plate.clickable{cursor:pointer}
.plate.clickable:hover{filter:brightness(1.12) !important;box-shadow:var(--glass-stroke),var(--glass-litedge),0 0 60px -10px var(--ac) !important}
.plate .expandcue{position:absolute;right:14px;bottom:12px;font-family:var(--micro);font-size:9px;letter-spacing:.22em;
  color:var(--ac);opacity:0;transition:opacity .3s;text-transform:uppercase}
.plate.clickable:hover .expandcue{opacity:.85}
