===== /home/yeff/public_html/devon/panel/assets/css/panel.css =====
/* 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)}
===== /home/yeff/public_html/devon/panel/assets/css/panel.runtime.fix.20260408_1.css =====
:root{
--bg:#071427;
--bg2:#0b1d39;
--panel:#0d2142;
--panel2:#0f2850;
--line:rgba(133,161,210,.18);
--text:#eef4ff;
--muted:#9db0d2;
--blue:#5aa2ff;
--green:#18c58f;
--red:#ff646e;
--amber:#ffbf53;
--violet:#8a7dff;
--radius:22px;
--shadow:0 18px 42px rgba(0,0,0,.26);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,var(--bg),#08101f);color:var(--text);font:14px/1.45 Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
button{font:inherit}
pre{margin:0}
.op-shell{
min-height:100vh;
display:grid;
grid-template-columns:280px 1fr;
gap:0;
background:linear-gradient(180deg,#050c1a,#071427);
}
.op-main{
padding:20px 24px;
}
.global-zone{
margin-bottom:20px;
}
.global-grid{
display:grid;
grid-template-columns:repeat(4,minmax(0,1fr));
gap:16px;
}
.card{
padding:20px;
border-radius:18px;
background:linear-gradient(180deg,#0d2142,#0a1b36);
border:1px solid rgba(133,161,210,.14);
box-shadow:0 10px 28px rgba(0,0,0,.25);
}
.op-sidebar,.card,.drawer-card{
background:linear-gradient(180deg,var(--panel),var(--bg2));
border:1px solid var(--line);
border-radius:var(--radius);
box-shadow:var(--shadow);
}
.op-sidebar{
padding:22px 16px 24px;
position:sticky;
top:0;
height:100vh;
overflow-y:auto;
overflow-x:hidden;
min-width:0;
border-right:1px solid var(--line);
background:rgba(4,10,22,.72);
backdrop-filter:blur(14px);
border-radius:0;
box-shadow:none
}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding:6px 4px 16px}
.brand-logo{display:block;width:210px;max-width:100%;height:auto}
.brand-subtitle{display:block;color:var(--muted);margin-top:0}
.side-block + .side-block{margin-top:20px}
.side-label{color:#9db0d2;text-transform:uppercase;font-size:12px;letter-spacing:.12em;margin-bottom:12px}
.sidebar-donut-wrap{display:flex;align-items:center;justify-content:center;min-height:168px}
.op-sidebar .sidebar-donut-wrap .donut{width:150px;height:150px}
.op-sidebar .sidebar-donut-wrap .donut svg{width:150px;height:150px}
.op-sidebar .sidebar-donut-wrap .donut-center strong{font-size:28px}
.op-sidebar .sidebar-donut-wrap .donut-center span{font-size:11px}
.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill-row-compact .pill{min-height:30px;padding:0 10px;font-size:12px}
.pill,.badge{
display:inline-flex;align-items:center;justify-content:center;
min-height:34px;padding:0 12px;border-radius:999px;
border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--text);font-weight:700
}
.pill.pass,.badge.pass{border-color:rgba(24,197,143,.35);color:#8ff2cf;background:rgba(24,197,143,.12)}
.pill.fail,.badge.fail{border-color:rgba(255,100,110,.35);color:#ffb2b8;background:rgba(255,100,110,.12)}
.pill.missing,.badge.missing{border-color:rgba(255,191,83,.35);color:#ffd99a;background:rgba(255,191,83,.12)}
.pill.running,.badge.running{border-color:rgba(90,162,255,.35);color:#b9d6ff;background:rgba(90,162,255,.12)}
.pill.pending,.badge.pending{border-color:rgba(138,125,255,.35);color:#cec8ff;background:rgba(138,125,255,.12)}
.badge-blue{border-color:rgba(90,162,255,.35);color:#b9d6ff;background:rgba(90,162,255,.12)}
.badge-violet{border-color:rgba(138,125,255,.35);color:#cec8ff;background:rgba(138,125,255,.12)}
.stage-nav{
display:flex;
flex-direction:column;
gap:16px;
}
.stage-group{
display:flex;
flex-direction:column;
gap:10px;
padding-bottom:14px;
border-bottom:1px solid rgba(255,255,255,.06);
}
.stage-group:last-child{
padding-bottom:0;
border-bottom:0;
}
.stage-group-head{
display:flex;
flex-direction:column;
gap:4px;
padding:0 2px;
}
.stage-group-head strong{
display:block;
font-size:15px;
line-height:1.2;
font-weight:800;
color:var(--text);
letter-spacing:.01em;
}
.stage-group-head small{
display:block;
color:var(--muted);
font-size:12px;
line-height:1.35;
letter-spacing:.02em;
word-break:break-word;
}
.stage-btn{
width:100%;
text-align:left;
border:1px solid rgba(133,161,210,.16);
background:rgba(255,255,255,.02);
color:var(--text);
border-radius:20px;
padding:14px 14px;
cursor:pointer;
display:grid;
grid-template-columns:minmax(0,1fr) auto;
align-items:start;
gap:12px;
transition:border-color .18s ease, background .18s ease, transform .18s ease;
}
.stage-btn:hover,
.stage-btn.active{
background:rgba(90,162,255,.10);
border-color:rgba(90,162,255,.28);
}
.stage-btn > span:first-child{
min-width:0;
}
.stage-btn strong{
display:block;
font-size:15px;
line-height:1.22;
font-weight:800;
margin:0 0 6px;
word-break:break-word;
}
.stage-btn small{
display:block;
color:var(--muted);
font-size:12px;
line-height:1.3;
letter-spacing:.01em;
}
.stage-btn-meta{
display:flex;
flex-direction:column;
align-items:flex-end;
gap:6px;
flex:0 0 auto;
min-width:74px;
}
.stage-btn-meta .badge{
min-height:24px;
padding:4px 8px;
border-radius:10px;
font-size:11px;
line-height:1;
font-weight:800;
white-space:nowrap;
justify-content:center;
}
.stage-btn-meta .badge-violet,
.stage-btn-meta .badge-blue{
background:rgba(255,255,255,.03);
}
.op-main{min-width:0
width: 100%;
max-width: none;
min-width: 0;
}
.hero{
display:flex;align-items:flex-start;justify-content:space-between;gap:16px;
padding:14px 4px 20px
}
.eyebrow{font-size:12px;letter-spacing:.14em;color:#8eb5ff;text-transform:uppercase;margin-bottom:8px}
.hero h1{margin:0 0 8px;font-size:42px;line-height:1.05}
.hero p{margin:0;color:var(--muted);font-size:16px}
.hero-actions{
display:flex;
flex-wrap:wrap;
justify-content:flex-end;
align-items:flex-start;
gap:8px;
max-width:430px;
}
.hero-actions::before{
content:"runtime data views";
flex:0 0 100%;
display:block;
text-align:right;
color:var(--muted);
font-size:11px;
line-height:1.2;
text-transform:uppercase;
letter-spacing:.12em;
margin-bottom:2px;
}
.btn{
border:1px solid var(--line);
border-radius:12px;
padding:8px 12px;
min-height:42px;
min-width:108px;
cursor:pointer;
background:rgba(255,255,255,.04);
color:var(--text);
font-weight:800;
font-size:12px;
line-height:1.05;
display:inline-flex;
align-items:center;
justify-content:center;
text-align:center;
}
.btn-primary{
background:linear-gradient(180deg,#4f93ff,#3272df);
border-color:transparent;
}
.btn-secondary:hover{background:rgba(255,255,255,.08)}
.layer-grid,
.top-grid{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:18px;
margin-bottom:18px;
}
.top-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.runtime-grid{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:18px;
margin-bottom:18px;
}
.workspace-grid{
display:grid;
grid-template-columns:minmax(0,1.08fr) minmax(0,1fr);
gap:18px;
}
.card{padding:18px;min-width:0}
.card-top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}
.card-title{font-size:12px;letter-spacing:.12em;color:#9db0d2;text-transform:uppercase}
.stat-card h2{margin:0 0 8px;font-size:30px}
.muted{color:var(--muted)}
.layer-list,.step-list{list-style:none;padding:0;margin:0}
.layer-list li,.step-list li{
display:flex;align-items:center;justify-content:space-between;gap:12px;
padding:10px 0;border-top:1px solid rgba(255,255,255,.06)
}
.layer-list li:first-child,.step-list li:first-child{border-top:0}
.donut-wrap{display:flex;align-items:center;justify-content:center;min-height:168px}
.donut{width:170px;height:170px;display:grid;place-items:center;position:relative}
.donut svg{width:170px;height:170px;transform:rotate(-90deg)}
.donut-center{
position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;
text-align:center
}
.donut-center strong{font-size:30px;line-height:1}
.donut-center span{font-size:12px;color:var(--muted);margin-top:6px}
.step-state{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#ffd99a}
.mini-metric-grid{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:12px;
}
.metric-box{