===== /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{