/* Devon Operator Panel — panel.css v20260409 */
:root {
  --bg0:#0c1117;--bg1:#111820;--bg2:#141e2e;--bg3:#0e1520;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.04);
  --text0:#dde3ef;--text1:#9aafc2;--text2:#5a6e82;--text3:#334455;
  --blue:#2563eb;--blue-lt:#60a5fa;
  --violet:#7c3aed;--violet-lt:#a78bfa;
  --green:#22c55e;--amber:#f59e0b;--red:#f87171;
  --mono:'IBM Plex Mono',monospace;--sans:'IBM Plex Sans',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;overflow:hidden;background:var(--bg0);font-family:var(--sans);color:var(--text0);font-size:13px}

/* SHELL */
#dp-shell{display:flex;height:100vh;overflow:hidden}

/* LEFT */
#dp-left{width:238px;flex-shrink:0;background:var(--bg1);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
#dp-brand{padding:14px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;flex-shrink:0}
#dp-logo{height:22px;width:auto;object-fit:contain}
#dp-brand-name{font-size:13px;font-weight:600;color:#e8ecf5}
#dp-brand-sub{font-size:8px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-top:2px}
.tree-label{font-size:8px;color:var(--text3);letter-spacing:1.2px;text-transform:uppercase;padding:12px 12px 4px;font-weight:500;flex-shrink:0;font-family:var(--mono)}
#dp-tree{flex:1;overflow-y:auto;padding-bottom:8px}
#dp-tree::-webkit-scrollbar{width:3px}
#dp-tree::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* PHASE */
.ph-row{display:flex;align-items:center;gap:6px;padding:5px 10px 5px 8px;cursor:pointer;border-left:2px solid transparent;transition:background 0.1s;user-select:none}
.ph-row:hover{background:rgba(255,255,255,0.03)}
.ph-row.ph-active{background:rgba(37,99,235,0.07);border-left-color:var(--blue)}
.ph-arrow{font-size:9px;color:var(--text3);width:12px;flex-shrink:0}
.ph-arrow.open{color:var(--text2)}
.ph-num{font-family:var(--mono);font-size:9px;color:var(--text3);width:18px;flex-shrink:0}
.ph-row.ph-active .ph-num{color:var(--blue)}
.ph-name{font-size:10px;color:var(--text2);flex:1;line-height:1.3}
.ph-row.ph-active .ph-name{color:var(--blue-lt)}
.ph-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}

/* CATEGORY */
.cat-row{display:flex;align-items:center;gap:6px;padding:3px 10px 3px 24px;cursor:pointer;border-left:2px solid transparent;transition:background 0.1s;margin-left:6px;user-select:none}
.cat-row:hover{background:rgba(255,255,255,0.02)}
.cat-row.cat-active{background:rgba(37,99,235,0.06);border-left-color:rgba(37,99,235,0.4)}
.cat-arrow{font-size:8px;color:var(--text3);width:10px;flex-shrink:0}
.cat-arrow.open{color:var(--text2)}
.cat-name{font-size:10px;color:#445566;flex:1;line-height:1.3}
.cat-row.cat-active .cat-name{color:#7ab4cc}
.cat-dot{width:4px;height:4px;border-radius:50%;flex-shrink:0}

/* BUCKET */
.bk-row{display:flex;align-items:center;gap:6px;padding:2px 10px 2px 38px;cursor:pointer;margin-left:6px;border-left:2px solid transparent;user-select:none}
.bk-row:hover{background:rgba(255,255,255,0.015)}
.bk-row.bk-active{background:rgba(245,158,11,0.05);border-left-color:rgba(245,158,11,0.3)}
.bk-name{font-family:var(--mono);font-size:9px;color:var(--text3)}
.bk-row.bk-active .bk-name{color:#fbbf24}

/* STATUS DOTS */
.d-ok{background:var(--green)}.d-wip{background:var(--amber)}.d-plan{background:#293a4d}

#dp-footer{padding:8px 12px;border-top:1px solid var(--border);font-size:8px;color:var(--text3);font-family:var(--mono);flex-shrink:0}

/* MAIN */
#dp-main{flex:1;overflow-y:auto;background:var(--bg0);min-width:0}
#dp-main::-webkit-scrollbar{width:4px}
#dp-main::-webkit-scrollbar-thumb{background:var(--border)}
.tree-err{padding:14px;color:var(--red);font-size:11px;font-family:var(--mono)}

/* SUMMARY */
.summary-wrap{padding:40px 28px}
.sum-title{font-size:20px;font-weight:600;color:#c5d3e8;margin-bottom:6px}
.sum-sub{font-size:11px;color:var(--text2);margin-bottom:28px;max-width:480px;line-height:1.6}
.sum-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;max-width:440px}
.sum-stat{background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:10px 12px}
.ss-lbl{font-size:8px;color:var(--text3);letter-spacing:0.8px;text-transform:uppercase;margin-bottom:5px;font-family:var(--mono)}
.ss-val{font-size:18px;font-weight:600;color:#dde5f2;font-family:var(--mono)}

/* PHASE OVERVIEW */
.ph-overview{padding:0}
.ph-ov-header{padding:14px 14px 12px;border-bottom:1px solid var(--border);background:var(--bg3)}
.ph-ov-eyebrow{font-size:8px;color:var(--text3);font-family:var(--mono);letter-spacing:0.8px;text-transform:uppercase;margin-bottom:4px}
.ph-ov-title{font-size:16px;font-weight:600;color:#c5d3e8;margin-bottom:3px}
.ph-ov-sub{font-size:10px;color:var(--text2)}
.ph-ov-cats{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.cat-card{background:var(--bg2);border:1px solid var(--border);border-radius:7px;padding:10px 12px;cursor:pointer;transition:border-color 0.1s}
.cat-card:hover{border-color:rgba(37,99,235,0.3)}
.cat-card-title{font-size:11px;font-weight:500;color:var(--text1);margin-bottom:3px}
.cat-card-sub{font-size:9px;color:var(--text3)}

/* CAT OVERVIEW */
.cat-overview{padding:0}
.cat-ov-header{padding:14px 14px 12px;border-bottom:1px solid var(--border);background:var(--bg3)}
.cat-bc{font-size:9px;color:var(--text3);font-family:var(--mono);margin-bottom:4px}
.cat-bc b{color:var(--blue-lt);font-weight:400}
.cat-ov-title{font-size:14px;font-weight:600;color:#c5d3e8;margin-bottom:2px}
.cat-ov-sub{font-size:10px;color:var(--text2)}
.bk-list{padding:12px 14px;display:flex;flex-direction:column;gap:5px}
.bk-list-label{font-size:8px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:6px;font-family:var(--mono)}
.bk-card{background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:8px 12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:border-color 0.1s}
.bk-card:hover{border-color:rgba(245,158,11,0.25);background:rgba(245,158,11,0.03)}
.bk-card-num{font-family:var(--mono);font-size:9px;color:var(--text3);width:16px}
.bk-card-name{font-family:var(--mono);font-size:10px;color:#5a6e82;flex:1}
.bk-card-desc{font-size:9px;color:var(--text3)}

/* BUCKET DETAIL */
.det-topbar{padding:9px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:var(--bg3);position:sticky;top:0;z-index:10}
.det-bc{font-size:9px;color:var(--text3);font-family:var(--mono)}
.det-bc b{color:var(--blue-lt);font-weight:400}
.det-pills{display:flex;gap:5px}
.pl{font-size:8px;font-family:var(--mono);padding:2px 6px;border-radius:2px;font-weight:500}
.pl-v{background:rgba(124,58,237,0.1);color:var(--violet-lt);border:1px solid rgba(124,58,237,0.15)}
.pl-bk{background:rgba(245,158,11,0.08);color:#fbbf24;border:1px solid rgba(245,158,11,0.12)}
.det-header{padding:14px 14px 10px;border-bottom:1px solid var(--border)}
.det-hd-top{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.det-phase{font-size:8px;color:var(--text3);font-family:var(--mono)}
.det-sep{color:var(--text3);font-size:10px}
.det-cat{font-size:8px;color:var(--text2);font-family:var(--mono)}
.det-title{font-size:14px;font-weight:600;color:#c5d3e8;margin-bottom:2px}
.det-sub{font-size:10px;color:var(--text3)}
.det-progress{display:flex;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border)}
.prog-card{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:6px;padding:8px 10px}
.prog-lbl{font-size:8px;color:var(--text3);font-family:var(--mono);margin-bottom:5px}
.prog-bar-w{height:3px;background:rgba(255,255,255,0.04);border-radius:2px;overflow:hidden;margin-bottom:3px}
.prog-bar{height:100%;background:var(--blue);border-radius:2px}
.prog-bar.prog-bk{background:var(--amber)}
.prog-nums{font-size:8px;color:var(--text3);font-family:var(--mono)}
.det-items{padding:10px 14px;display:flex;flex-direction:column;gap:6px}
.items-label{font-size:8px;color:var(--text3);letter-spacing:1px;text-transform:uppercase;margin-bottom:4px;font-family:var(--mono)}
.item-card{background:var(--bg2);border:1px solid var(--border);border-left:2px solid #293a4d;border-radius:6px;padding:10px 12px;display:flex;align-items:flex-start;gap:10px}
.item-card.item-ok{border-left-color:rgba(34,197,94,0.4)}
.item-card.item-fail{border-left-color:rgba(248,113,113,0.4)}
.item-ico{width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;flex-shrink:0;background:rgba(255,255,255,0.04);color:var(--text2);margin-top:1px}
.item-ok .item-ico{background:rgba(34,197,94,0.1);color:var(--green)}
.item-fail .item-ico{background:rgba(248,113,113,0.1);color:var(--red)}
.item-body{flex:1;min-width:0}
.item-title{font-size:11px;font-weight:500;color:var(--text1);margin-bottom:2px}
.item-role{font-size:9px;color:var(--text2);line-height:1.4;margin-bottom:3px}
.item-ev{font-size:8px;font-family:var(--mono);color:var(--text3);padding:2px 5px;background:rgba(255,255,255,0.02);border-radius:2px;border-left:2px solid rgba(37,99,235,0.2);word-break:break-all}
.item-badge{font-size:8px;font-family:var(--mono);padding:2px 6px;border-radius:2px;font-weight:500;flex-shrink:0;align-self:flex-start;margin-top:1px}
.st-pass{background:rgba(34,197,94,0.08);color:var(--green);border:1px solid rgba(34,197,94,0.12)}
.st-fail{background:rgba(248,113,113,0.08);color:var(--red);border:1px solid rgba(248,113,113,0.12)}
.st-missing,.st-planned{background:rgba(51,68,85,0.2);color:var(--text2);border:1px solid rgba(51,68,85,0.25)}

/* RIGHT */
#dp-right{width:50px;flex-shrink:0;background:var(--bg1);border-left:1px solid var(--border);display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:3px}
.ib{width:34px;height:34px;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;gap:2px;border:1px solid transparent;background:transparent;transition:background 0.12s,border-color 0.12s}
.ib:hover{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.07)}
.ib svg{width:13px;height:13px;fill:none;stroke:#334455;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.ib:hover svg{stroke:var(--text2)}
.ib span{font-size:6px;color:var(--text3);text-align:center;line-height:1.2;font-family:var(--mono)}
.ib:hover span{color:var(--text2)}
.ib-sep{width:18px;height:1px;background:var(--border);margin:3px 0}

/* DRAWER */
#dp-drawer{position:fixed;top:0;right:50px;width:400px;height:100vh;background:var(--bg1);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translateX(420px);transition:transform 0.2s ease;z-index:100}
#dp-drawer.open{transform:translateX(0)}
#dp-drawer-header{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
#dp-drawer-title{font-size:11px;font-weight:500;color:var(--text1)}
#dp-drawer-close{background:none;border:none;color:var(--text2);cursor:pointer;font-size:12px;padding:2px 6px;border-radius:3px}
#dp-drawer-close:hover{color:var(--text0);background:rgba(255,255,255,0.05)}
#dp-drawer-pre{flex:1;overflow-y:auto;padding:12px 14px;font-family:var(--mono);font-size:10px;color:var(--text1);line-height:1.6;white-space:pre-wrap;word-break:break-word}
#dp-drawer-pre::-webkit-scrollbar{width:3px}
#dp-drawer-pre::-webkit-scrollbar-thumb{background:var(--border)}
