/* ============================================================
   THE PYLON PLATFORM — Workspace (Pro)
   Enterprise application shell. One tall app window the three
   products live inside. Prefix: wx-
   ============================================================ */

[data-pylon-workspace]{
  --bg:#09090b; --app:#0b0b0d; --bar:#0e0e12; --panel:#101014; --panel-2:#131318;
  --row:rgba(255,255,255,0.022); --row-h:rgba(255,255,255,0.04);
  --line:rgba(255,255,255,0.07); --line-2:rgba(255,255,255,0.11);
  --tx:#f4f4f5; --tx2:#a1a1aa; --tx3:#71717a; --tx4:#52525b;
  --font-d:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-b:'DM Sans',system-ui,sans-serif; --font-m:'JetBrains Mono',monospace;
  --ease:cubic-bezier(0.16,1,0.3,1); --ease-out:cubic-bezier(0.33,1,0.68,1);
  --ok:#34d399; --warn:#e8a820; --bad:#f26d6d; --info:#60a5fa; --neu:#9ca3af;
  --ac:#14b8a6; --ac-hi:#2dd4bf;
  display:block;
}
[data-pylon-workspace] *{box-sizing:border-box}

/* ---- section frame ---- */
.wx-section{position:relative;padding:clamp(2rem,4vw,3.25rem) 0 clamp(5rem,9vw,7.5rem);overflow:hidden}
.wx-wrap{max-width:1520px;margin:0 auto;padding:0 clamp(1.25rem,4vw,2.25rem)}
.wx-glow{position:absolute;left:50%;top:18%;width:min(1100px,92vw);height:560px;transform:translateX(-50%);
  background:radial-gradient(ellipse at center,color-mix(in srgb,var(--ac) 16%,transparent),transparent 62%);
  filter:blur(30px);opacity:0;transition:opacity 1.2s var(--ease) .15s;pointer-events:none;z-index:0}
.wx-section[data-active] .wx-glow{opacity:.5}

/* ---- header ---- */
.wx-head{position:relative;z-index:2;max-width:680px;margin:0 auto clamp(2.25rem,3.5vw,3rem);text-align:center}
.wx-eyebrow{font-family:var(--font-m);font-size:0.6875rem;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--tx3);
  display:inline-flex;align-items:center;gap:0.6rem;margin-bottom:1.1rem;opacity:0;transform:translateY(10px);transition:.7s var(--ease) .1s}
.wx-eyebrow::before,.wx-eyebrow::after{content:'';width:1.4rem;height:1px;background:var(--line-2)}
.wx-title{font-family:var(--font-d);font-size:clamp(1.9rem,4vw,2.85rem);font-weight:700;letter-spacing:-0.035em;line-height:1.07;
  opacity:0;transform:translateY(14px);transition:.8s var(--ease) .18s}
.wx-title .muted{color:var(--tx4)}
.wx-sub{margin-top:1rem;color:var(--tx2);font-size:1.0625rem;line-height:1.65;opacity:0;transform:translateY(14px);transition:.8s var(--ease) .26s}
.wx-section[data-active] .wx-eyebrow,
.wx-section[data-active] .wx-title,
.wx-section[data-active] .wx-sub{opacity:1;transform:none}

/* ============================================================
   THE APP WINDOW + signature 3D reveal
   ============================================================ */
.wx-stage{position:relative;z-index:1;perspective:2200px;perspective-origin:50% -8%}
.wx-win{position:relative;border-radius:14px;background:var(--app);overflow:hidden;
  border:1px solid var(--line-2);
  box-shadow:0 1px 0 rgba(255,255,255,0.04) inset, 0 40px 90px -30px rgba(0,0,0,0.85), 0 12px 30px -12px rgba(0,0,0,0.6);
  transform-style:preserve-3d;
  opacity:0;transform:rotateX(9deg) scale(0.95) translateY(28px);
  transition:opacity 1s var(--ease), transform 1.1s var(--ease);
  will-change:transform,opacity}
.wx-section[data-active] .wx-win{opacity:1;transform:none}
.wx-win::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:6;
  background:linear-gradient(90deg,transparent,var(--ac),transparent);opacity:.7}

/* grid: topbar / body(nav | main | aside) */
.wx-grid{display:grid;grid-template-rows:auto 1fr;height:clamp(660px,82vh,780px)}
.wx-body{display:grid;grid-template-columns:170px 1fr 296px;min-height:0}

/* ---- product switcher (above the window) ---- */
.wx-switch{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:0.6rem;margin-bottom:1rem;
  opacity:0;transform:translateY(12px);transition:.8s var(--ease) .3s}
.wx-section[data-active] .wx-switch{opacity:1;transform:none}
.wx-switch-lbl{font-family:var(--font-m);font-size:0.6rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--tx4)}
.wx-switch-seg{display:flex;gap:0.4rem;background:rgba(255,255,255,0.025);border:1px solid var(--line);border-radius:13px;padding:0.4rem}
.wx-stab{display:flex;align-items:center;gap:0.6rem;padding:0.5rem 0.85rem 0.5rem 0.55rem;border-radius:9px;cursor:pointer;
  background:transparent;border:1px solid transparent;color:var(--tx3);font-family:inherit;transition:all .3s var(--ease);text-align:left}
.wx-stab:hover{background:rgba(255,255,255,0.04);color:var(--tx2)}
.wx-stab-ic{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .3s var(--ease);opacity:0.7}
.wx-stab-tx{display:flex;flex-direction:column;line-height:1.15}
.wx-stab-nm{font-family:var(--font-d);font-weight:700;font-size:0.9rem;letter-spacing:-0.01em;color:var(--tx2);transition:color .3s}
.wx-stab-tg{font-family:var(--font-m);font-size:0.585rem;letter-spacing:0.04em;color:var(--tx4)}
.wx-stab.active{background:color-mix(in srgb,var(--pc) 12%,transparent);border-color:color-mix(in srgb,var(--pc) 40%,var(--line));
  box-shadow:0 0 22px -8px color-mix(in srgb,var(--pc) 80%,transparent)}
.wx-stab.active .wx-stab-ic{opacity:1;filter:drop-shadow(0 0 6px color-mix(in srgb,var(--pc) 55%,transparent))}
.wx-stab:hover .wx-stab-ic{opacity:1}
.wx-stab.active .wx-stab-nm{color:#fff}
.wx-stab.active .wx-stab-tg{color:var(--pc-hi)}

/* ---- global top bar ---- */
.wx-top{display:flex;align-items:center;gap:0.85rem;height:52px;padding:0 0.9rem;border-bottom:1px solid var(--line);background:var(--bar)}
.wx-brand{display:flex;align-items:center;gap:0.55rem;padding-right:0.2rem}
.wx-brand svg{height:16px;width:auto}
.wx-brand b{font-family:'Inter',var(--font-b);font-weight:700;font-size:0.84rem;letter-spacing:-0.02em;color:#fff}
.wx-chev{color:var(--tx4);font-size:0.7rem;margin-left:0.1rem}
.wx-vbar{width:1px;height:20px;background:var(--line)}
.wx-crumb{font-family:var(--font-m);font-size:0.68rem;color:var(--tx4);letter-spacing:0.02em;white-space:nowrap;display:flex;align-items:center;gap:0.4rem}
.wx-crumb b{color:var(--tx2);font-weight:500}
.wx-crumb .ac{color:var(--ac-hi);transition:color .4s}
.wx-search{margin-left:auto;display:flex;align-items:center;gap:0.55rem;width:clamp(180px,26%,300px);height:32px;padding:0 0.6rem;
  background:rgba(255,255,255,0.03);border:1px solid var(--line);border-radius:8px;color:var(--tx4)}
.wx-search svg{width:13px;height:13px;flex-shrink:0}
.wx-search span{font-size:0.76rem;color:var(--tx4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-kbd{margin-left:auto;display:flex;gap:2px;flex-shrink:0}
.wx-kbd b{font-family:var(--font-m);font-size:0.6rem;color:var(--tx3);background:rgba(255,255,255,0.05);border:1px solid var(--line);border-radius:4px;padding:0.05rem 0.3rem;font-weight:500}
.wx-top-act{display:flex;align-items:center;gap:0.5rem}
.wx-icon-btn{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--tx3);position:relative;border:1px solid transparent}
.wx-icon-btn:hover{background:rgba(255,255,255,0.04);color:var(--tx2)}
.wx-icon-btn svg{width:15px;height:15px}
.wx-dot-badge{position:absolute;top:6px;right:7px;width:5px;height:5px;border-radius:50%;background:var(--bad);box-shadow:0 0 0 2px var(--bar)}
.wx-ava{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#3f3f46,#27272a);border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:0.64rem;color:#e4e4e7}

/* ---- app rail (product switcher) ---- */
.wx-rail{border-right:1px solid var(--line);background:rgba(0,0,0,0.25);display:flex;flex-direction:column;align-items:center;padding:0.7rem 0;gap:0.45rem}
.wx-app{width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;
  font-family:var(--font-d);font-weight:700;font-size:0.95rem;color:var(--tx3);
  background:rgba(255,255,255,0.025);border:1px solid var(--line);transition:all .3s var(--ease)}
.wx-app:hover{color:var(--tx)} 
.wx-app.active{color:#fff;background:color-mix(in srgb,var(--pc) 16%,transparent);border-color:color-mix(in srgb,var(--pc) 50%,transparent);box-shadow:0 0 18px -4px color-mix(in srgb,var(--pc) 70%,transparent)}
.wx-app.active::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:18px;border-radius:3px;background:var(--pc)}
.wx-app .tip{position:absolute;left:46px;top:50%;transform:translateY(-50%) translateX(-4px);background:#1c1c22;border:1px solid var(--line-2);color:var(--tx);
  font-family:var(--font-b);font-size:0.7rem;padding:0.25rem 0.5rem;border-radius:6px;white-space:nowrap;opacity:0;pointer-events:none;transition:.2s var(--ease);z-index:20}
.wx-app:hover .tip{opacity:1;transform:translateY(-50%) translateX(0)}
.wx-rail-sp{flex:1}
.wx-rail-mini{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--tx4)}
.wx-rail-mini svg{width:15px;height:15px}

/* ---- contextual nav ---- */
.wx-nav{border-right:1px solid var(--line);background:rgba(255,255,255,0.008);padding:0.85rem 0.6rem;display:flex;flex-direction:column;gap:1px;min-width:0}
.wx-nav-h{font-family:var(--font-m);font-size:0.6rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--tx4);padding:0.3rem 0.55rem 0.55rem}
.wx-nav-i{display:flex;align-items:center;gap:0.6rem;padding:0.46rem 0.55rem;border-radius:7px;cursor:pointer;color:var(--tx3);transition:background .2s,color .2s;position:relative}
.wx-nav-i svg{width:15px;height:15px;flex-shrink:0;opacity:.85}
.wx-nav-i span{font-size:0.815rem;font-weight:500;letter-spacing:-0.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.wx-nav-i .ct{font-family:var(--font-m);font-size:0.62rem;color:var(--tx4)}
.wx-nav-i:hover{background:var(--row-h);color:var(--tx2)}
.wx-nav-i.active{background:color-mix(in srgb,var(--pc) 13%,transparent);color:#fff}
.wx-nav-i.active svg{opacity:1;color:var(--ac-hi)}
.wx-nav-i.active .ct{color:var(--ac-hi)}
.wx-nav-div{height:1px;background:var(--line);margin:0.6rem 0.55rem}
.wx-nav-i + .wx-nav-h{margin-top:0.55rem}
.wx-nav-clickable{cursor:pointer}
.wx-nav-clickable:hover{background:var(--row-h)}

/* ---- main content ---- */
.wx-main{min-width:0;display:flex;flex-direction:column;overflow:hidden;background:
  radial-gradient(120% 70% at 100% 0,rgba(255,255,255,0.012),transparent 60%)}
.wx-main-head{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.15rem 0.9rem;border-bottom:1px solid var(--line)}
.wx-mh-l{min-width:0}
.wx-mh-title{font-family:var(--font-d);font-size:1.18rem;font-weight:700;letter-spacing:-0.025em;color:#fff;line-height:1.2}
.wx-mh-sub{font-size:0.78rem;color:var(--tx3);margin-top:0.15rem}
.wx-mh-r{margin-left:auto;display:flex;align-items:center;gap:0.5rem;flex-shrink:0}
.wx-seg{display:flex;background:rgba(255,255,255,0.035);border:1px solid var(--line);border-radius:7px;padding:2px}
.wx-seg b{font-family:var(--font-m);font-size:0.64rem;color:var(--tx4);padding:0.22rem 0.5rem;border-radius:5px;cursor:pointer}
.wx-seg b.on{background:var(--panel-2);color:var(--tx);box-shadow:0 1px 2px rgba(0,0,0,0.4)}
.wx-btn{display:inline-flex;align-items:center;gap:0.4rem;font-family:var(--font-d);font-size:0.76rem;font-weight:600;height:30px;padding:0 0.7rem;border-radius:7px;cursor:pointer;border:1px solid var(--line);color:var(--tx2);background:rgba(255,255,255,0.02);white-space:nowrap}
.wx-btn svg{width:13px;height:13px}
.wx-btn:hover{color:var(--tx);border-color:var(--line-2)}
.wx-btn.primary{color:#0b0b0d;background:var(--ac);border-color:var(--ac);font-weight:700}
.wx-btn.primary:hover{background:var(--ac-hi)}

.wx-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem 1.15rem 1.15rem;display:flex;flex-direction:column;gap:0.95rem;position:relative;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.14) transparent}
.wx-scroll::-webkit-scrollbar{width:7px}
.wx-scroll::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.11);border-radius:4px}
.wx-scroll::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.18)}
.wx-scroll::-webkit-scrollbar-track{background:transparent}
.wx-scroll::after{content:none}

/* KPI row */
.wx-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:0.7rem}
.wx-kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:0.7rem 0.8rem;position:relative;overflow:hidden}
.wx-kpi-k{font-family:var(--font-m);font-size:0.585rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--tx4)}
.wx-kpi-row{display:flex;align-items:flex-end;justify-content:space-between;gap:0.4rem;margin-top:0.4rem}
.wx-kpi-v{font-family:var(--font-d);font-weight:700;font-size:1.5rem;letter-spacing:-0.03em;color:#fff;line-height:1;font-variant-numeric:tabular-nums}
.wx-kpi-v .u{font-size:0.78rem;color:var(--tx3);font-weight:600;margin-left:0.1rem}
.wx-kpi-d{font-family:var(--font-m);font-size:0.64rem;display:flex;align-items:center;gap:0.2rem;white-space:nowrap}
.wx-kpi-spark{margin-top:0.5rem;height:18px;width:100%}

/* panels grid */
.wx-cols{display:grid;grid-template-columns:1.55fr 1fr;gap:0.8rem;flex:1;min-height:0}
.wx-cols-cmd{grid-template-columns:1fr 1.2fr;flex:0 0 auto;min-height:216px}
.wx-radar-box{height:134px;width:100%;display:flex;align-items:center;justify-content:center}
.wx-radar-box svg{max-height:100%;max-width:100%}
.wx-p-full{flex:1;min-height:0}
.wx-sevpill{font-family:var(--font-m);font-size:0.6rem;letter-spacing:0.03em;border:1px solid;border-radius:5px;padding:0.1rem 0.42rem;white-space:nowrap;display:inline-block}
.wx-tablewrap{flex:1;min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.14) transparent}
.wx-tablewrap::-webkit-scrollbar{width:7px}
.wx-tablewrap::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.11);border-radius:4px}
.wx-tablewrap::-webkit-scrollbar-track{background:transparent}
.wx-tablewrap .wx-table thead th{position:sticky;top:0;z-index:1}

/* Anvil kanban board */
.wx-p-board{flex:0 0 auto}
.wx-kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:0.6rem;padding:0.7rem;overflow:visible;align-items:start}
.wx-kcol{display:flex;flex-direction:column;gap:0.45rem;min-width:0}
.wx-kcol-h{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-m);font-size:0.58rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx4);padding:0 0.15rem 0.35rem;border-bottom:1px solid var(--line)}
.wx-kcol-h span{color:var(--tx3)}
.wx-kcards{display:flex;flex-direction:column;gap:0.45rem;min-height:0}
.wx-kcard{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:0.55rem 0.6rem;display:flex;flex-direction:column;gap:0.32rem;
  box-shadow:0 1px 2px rgba(0,0,0,0.3);transition:border-color .2s,transform .2s}
.wx-kcard:hover{border-color:var(--line-2);transform:translateY(-1px)}
.wx-kcard-top{display:flex;align-items:center;justify-content:space-between;gap:0.4rem}
.wx-kcard-nm{font-family:var(--font-d);font-size:0.76rem;font-weight:600;color:#fff;letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-kcard-g{font-family:var(--font-m);font-size:0.6rem;border:1px solid;border-radius:5px;padding:0.04rem 0.28rem;flex-shrink:0}
.wx-kcard-sub{font-family:var(--font-m);font-size:0.585rem;color:var(--tx4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-kcard-foot{display:flex;align-items:center;justify-content:space-between;margin-top:0.1rem}
.wx-kcard-f{display:inline-flex;align-items:center;gap:0.25rem;font-family:var(--font-m);font-size:0.6rem;color:var(--warn)}
.wx-kcard-f.ok{color:var(--tx4)}
.wx-kcard-f svg{width:11px;height:11px}

/* Command radar + roadmap */
.wx-radar-foot{font-family:var(--font-m);font-size:0.6rem;color:var(--tx3);text-align:center}
.wx-radar-foot b{font-weight:500}
.wx-p-road{flex:0 0 auto}
.wx-rowbars-h{gap:0.8rem}
.wx-roadmap{display:flex;flex-direction:column;gap:0.45rem}
.wx-rmrow{display:grid;grid-template-columns:1.4fr 2fr auto auto;gap:0.7rem;align-items:center}
.wx-rm-k{font-size:0.78rem;color:var(--tx);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:0.4rem;letter-spacing:-0.01em}
.wx-rm-st{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.72rem;color:var(--tx2);min-width:72px}
.wx-rm-v{font-family:var(--font-m);font-size:0.7rem;color:var(--tx3);text-align:right;min-width:30px}

/* panel base */
.wx-panel{background:var(--panel);border:1px solid var(--line);border-radius:10px;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.wx-panel-h{display:flex;align-items:center;gap:0.5rem;padding:0.6rem 0.8rem;border-bottom:1px solid var(--line)}
.wx-panel-t{font-family:var(--font-d);font-size:0.8rem;font-weight:700;color:#fff;letter-spacing:-0.01em;white-space:nowrap}
.wx-panel-m{font-family:var(--font-m);font-size:0.6rem;color:var(--tx4);margin-left:auto;white-space:nowrap}
.wx-panel-link{font-family:var(--font-d);font-size:0.7rem;font-weight:600;color:var(--ac);margin-left:auto;white-space:nowrap;cursor:pointer}

/* data table */
.wx-table{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
.wx-table thead th{font-family:var(--font-m);font-size:0.56rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx4);text-align:left;font-weight:500;
  padding:0.5rem 0.8rem;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);white-space:nowrap}
.wx-table thead th.num{text-align:right}
.wx-table tbody td{padding:0.5rem 0.8rem;border-bottom:1px solid var(--line);font-size:0.78rem;color:var(--tx2);white-space:nowrap}
.wx-table tbody tr:last-child td{border-bottom:none}
.wx-table tbody tr{transition:background .15s}
.wx-table tbody tr:hover{background:var(--row-h)}
.wx-td-name{display:flex;align-items:center;gap:0.55rem}
.wx-mono{font-family:var(--font-m);font-size:0.74rem}
.wx-vname{color:#fff;font-weight:500;font-size:0.8rem}
.wx-sub2{color:var(--tx4);font-size:0.66rem}
.wx-tier{font-family:var(--font-m);font-size:0.62rem;color:var(--tx3);border:1px solid var(--line);border-radius:5px;padding:0.08rem 0.34rem}
.wx-num{text-align:right;font-family:var(--font-m);font-size:0.76rem}
.wx-scorecell{display:flex;align-items:center;gap:0.5rem;justify-content:flex-end}
.wx-minibar{width:48px;height:4px;border-radius:3px;background:rgba(255,255,255,0.08);overflow:hidden}
.wx-minibar i{display:block;height:100%;border-radius:3px}
.wx-stat{display:inline-flex;align-items:center;gap:0.4rem;font-size:0.74rem}
.wx-sdot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.wx-ava-sm{width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-d);font-weight:700;font-size:0.55rem;flex-shrink:0}

/* chart panel bodies */
.wx-panel-body{padding:0.8rem;flex:1;min-height:0;display:flex;flex-direction:column;gap:0.7rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.14) transparent}
.wx-panel-body::-webkit-scrollbar{width:7px}
.wx-panel-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.11);border-radius:4px}
.wx-panel-body::-webkit-scrollbar-track{background:transparent}
.wx-legend{display:flex;flex-direction:column;gap:0.45rem}
.wx-leg{display:flex;align-items:center;gap:0.5rem;font-size:0.72rem;color:var(--tx2)}
.wx-leg .d{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.wx-leg b{margin-left:auto;font-family:var(--font-m);color:var(--tx3);font-weight:500}
.wx-donut-wrap{display:flex;align-items:center;gap:1rem}
.wx-donut{position:relative;flex-shrink:0}
.wx-donut-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.wx-donut-v{font-family:var(--font-d);font-weight:700;font-size:1.15rem;color:#fff;line-height:1}
.wx-donut-l{font-family:var(--font-m);font-size:0.52rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--tx4);margin-top:0.15rem}
.wx-rowbars{display:flex;flex-direction:column;gap:0.6rem}
.wx-rb{display:grid;grid-template-columns:80px 1fr 30px;gap:0.55rem;align-items:center}
.wx-rb-k{font-size:0.72rem;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:0.35rem}
.wx-rb-src{font-family:var(--font-m);font-size:0.5rem;color:var(--ac-hi);border:1px solid color-mix(in srgb,var(--ac) 35%,var(--line));border-radius:4px;padding:0 0.22rem}
.wx-rb-bar{height:5px;border-radius:3px;background:rgba(255,255,255,0.07);overflow:hidden}
.wx-rb-bar i{display:block;height:100%;border-radius:3px}
.wx-rb-v{font-family:var(--font-m);font-size:0.66rem;color:var(--tx3);text-align:right}

/* ---- aside (Warden inspector + activity) ---- */
.wx-aside{border-left:1px solid var(--line);background:rgba(0,0,0,0.18);display:flex;flex-direction:column;min-height:0;overflow:hidden}
.wx-aside-sec{padding:0.85rem 0.9rem;border-bottom:1px solid var(--line)}
.wx-warden-h{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.6rem}
.wx-warden-badge{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.wx-warden-t{font-family:var(--font-d);font-size:0.78rem;font-weight:700;color:#fff}
.wx-warden-live{display:flex;align-items:center;gap:0.3rem;margin-left:auto;font-family:var(--font-m);font-size:0.56rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx4)}
.wx-live-dot{width:6px;height:6px;border-radius:50%;background:var(--ac);animation:wxPulse 2.2s var(--ease) infinite}
@keyframes wxPulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--ac) 55%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.wx-warden-card{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:0.6rem 0.7rem}
.wx-warden-tag{display:inline-flex;align-items:center;font-family:var(--font-m);font-size:0.54rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 40%,var(--line));border-radius:5px;padding:0.06rem 0.34rem;margin-bottom:0.4rem}
.wx-warden-headline{font-family:var(--font-d);font-size:0.82rem;font-weight:600;color:#fff;line-height:1.3;letter-spacing:-0.01em}
.wx-warden-body{font-size:0.74rem;color:var(--tx2);line-height:1.55;margin-top:0.35rem}
.wx-warden-body b{color:#fff;font-weight:500}
.wx-warden-act{display:flex;gap:0.4rem;margin-top:0.55rem}
.wx-warden-btn{font-family:var(--font-d);font-size:0.68rem;font-weight:600;padding:0.3rem 0.55rem;border-radius:6px;cursor:pointer;border:1px solid var(--line);color:var(--tx2);white-space:nowrap}
.wx-warden-btn.ac{color:var(--ac);border-color:color-mix(in srgb,var(--ac) 40%,var(--line));background:color-mix(in srgb,var(--ac) 9%,transparent)}

.wx-activity{flex:1;min-height:0;display:flex;flex-direction:column;padding:0.85rem 0.9rem;overflow:hidden}
.wx-activity-h{font-family:var(--font-m);font-size:0.6rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--tx4);margin-bottom:0.7rem;display:flex;align-items:center;gap:0.5rem}
.wx-activity-h .ct{margin-left:auto;color:var(--tx4)}
.wx-feed{display:flex;flex-direction:column;gap:0.05rem;position:relative}
.wx-ev{display:grid;grid-template-columns:22px 1fr;gap:0.55rem;padding:0.5rem 0;position:relative}
.wx-ev:not(:last-child)::before{content:'';position:absolute;left:10.5px;top:26px;bottom:-6px;width:1px;background:var(--line)}
.wx-ev-ic{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1;
  background:var(--panel);border:1px solid var(--line)}
.wx-ev-ic svg{width:12px;height:12px}
.wx-ev-tx{min-width:0}
.wx-ev-t{font-size:0.74rem;color:var(--tx2);line-height:1.4}
.wx-ev-t b{color:#fff;font-weight:500}
.wx-ev-t .from{font-family:var(--font-m);font-size:0.58rem;padding:0 0.26rem;border-radius:4px;border:1px solid var(--line);color:var(--tx3);white-space:nowrap}
.wx-ev-meta{font-family:var(--font-m);font-size:0.6rem;color:var(--tx4);margin-top:0.18rem}

/* ============================================================
   ENTRANCE STAGGER (after window settles)
   ============================================================ */
.wx-section .wx-stagger{opacity:0;transform:translateY(8px)}
.wx-section[data-active] .wx-stagger{animation:wxIn .55s var(--ease-out) forwards}
@keyframes wxIn{to{opacity:1;transform:none}}
/* product swap re-render uses same animation immediately */
.wx-swap .wx-stagger{opacity:0;transform:translateY(8px);animation:wxIn .5s var(--ease-out) forwards}

/* ---- view styles: connections / supply chain / roadmap / assessments / reports ---- */
.wx-sc-list{display:flex;flex-direction:column;gap:0.5rem}
.wx-sc-row{display:grid;grid-template-columns:190px 1fr;gap:0.8rem;align-items:center;padding:0.5rem 0;border-top:1px solid var(--line)}
.wx-sc-row:first-child{border-top:none}
.wx-sc-t1{display:flex;align-items:center;gap:0.5rem;font-family:var(--font-d);font-size:0.8rem;font-weight:600;color:#fff;min-width:0}
.wx-sc-t1 > span:not(.wx-tier){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-sc-subs{display:flex;flex-wrap:wrap;gap:0.4rem}
.wx-sc-sub{display:inline-flex;align-items:center;gap:0.3rem;font-family:var(--font-m);font-size:0.62rem;color:var(--tx2);border:1px solid var(--line);border-radius:6px;padding:0.18rem 0.42rem;background:rgba(255,255,255,0.015)}
.wx-sc-sub svg{width:11px;height:11px;color:var(--tx4)}
.wx-sc-banner{display:flex;gap:0.55rem;align-items:flex-start;background:color-mix(in srgb,var(--bad) 9%,transparent);border:1px solid color-mix(in srgb,var(--bad) 28%,var(--line));border-radius:9px;padding:0.6rem 0.7rem;font-size:0.76rem;color:var(--tx2);line-height:1.5}
.wx-sc-banner svg{width:15px;height:15px;color:var(--bad);flex-shrink:0;margin-top:1px}
.wx-sc-banner b{color:#fff;font-weight:600}
.wx-rmrow2{display:grid;grid-template-columns:1.5fr 1.7fr auto auto;gap:0.7rem;align-items:center;padding:0.55rem 0;border-top:1px solid var(--line)}
.wx-rmrow2:first-child{border-top:none}
.wx-rm2-k{display:flex;flex-direction:column;gap:0.12rem;font-size:0.8rem;color:#fff;font-weight:500;min-width:0;letter-spacing:-0.01em}
.wx-rm2-sub{font-family:var(--font-m);font-size:0.6rem;color:var(--tx4);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-q{font-family:var(--font-m);font-size:0.62rem;color:var(--tx3);border:1px solid var(--line);border-radius:5px;padding:0.08rem 0.4rem;white-space:nowrap}
.wx-q-axis{display:grid;grid-template-columns:repeat(4,1fr);font-family:var(--font-m);font-size:0.55rem;letter-spacing:0.1em;color:var(--tx4);border-bottom:1px solid var(--line);padding-bottom:0.4rem;margin-bottom:0.2rem}
.wx-chat{gap:0.55rem!important;overflow-y:auto}
.wx-turn{display:flex;flex-direction:column;gap:0.2rem;max-width:90%}
.wx-turn.q{align-self:flex-start}
.wx-turn.a{align-self:flex-end;align-items:flex-end}
.wx-turn-who{font-family:var(--font-m);font-size:0.55rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--tx4)}
.wx-turn-bubble{font-size:0.76rem;line-height:1.5;padding:0.45rem 0.65rem;border-radius:10px}
.wx-turn.q .wx-turn-bubble{background:rgba(255,255,255,0.035);color:var(--tx2);border:1px solid var(--line);border-top-left-radius:3px}
.wx-turn.a .wx-turn-bubble{background:color-mix(in srgb,var(--ac) 13%,transparent);color:#fff;border:1px solid color-mix(in srgb,var(--ac) 30%,var(--line));border-top-right-radius:3px}
.wx-draft-card{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:0.65rem 0.8rem;display:flex;flex-direction:column;gap:0.25rem}
.wx-draft-k{font-family:var(--font-m);font-size:0.54rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--tx4);margin-top:0.35rem}
.wx-draft-v{font-family:var(--font-d);font-size:0.82rem;font-weight:600;color:#fff}
.wx-draft-resp{font-size:0.75rem;color:var(--tx2);line-height:1.55}
.wx-draft-row{display:flex;gap:1rem;align-items:flex-start;margin-top:0.1rem}
.wx-draft-score{font-family:var(--font-d);font-weight:700;font-size:1.15rem;color:var(--ac-hi);line-height:1}
.wx-draft-score span{font-size:0.68rem;color:var(--tx3);font-weight:600}
.wx-draft-chips{display:flex;flex-wrap:wrap;gap:0.3rem;margin-top:0.15rem}
.wx-draft-chip{font-family:var(--font-m);font-size:0.57rem;color:var(--tx2);border:1px solid var(--line);border-radius:5px;padding:0.1rem 0.36rem}
.wx-draft-ev{display:inline-flex;align-items:center;gap:0.35rem;font-family:var(--font-m);font-size:0.65rem;color:var(--ac-hi)}
.wx-draft-ev svg{width:12px;height:12px}
.wx-rep-ic{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--tx3);flex-shrink:0}
.wx-rep-ic svg{width:13px;height:13px}
/* assessment self-writing UI */
.wx-asmt-ctl{display:flex;align-items:center;gap:0.4rem;flex-wrap:wrap;margin-bottom:0.1rem}
.wx-asmt-code{font-family:var(--font-m);font-size:0.62rem;font-weight:600;color:var(--ac-hi);border:1px solid color-mix(in srgb,var(--ac) 40%,var(--line));border-radius:5px;padding:0.08rem 0.34rem}
.wx-asmt-ctlname{font-family:var(--font-d);font-size:0.8rem;font-weight:600;color:#fff}
.wx-asmt-fw{font-family:var(--font-m);font-size:0.55rem;color:var(--tx4);margin-left:auto}
.wx-asmt-sugg{font-family:var(--font-m);font-size:0.5rem;letter-spacing:0.06em;text-transform:uppercase;color:var(--ac-hi);margin-left:0.45rem}
.wx-asmt-opts{display:flex;flex-wrap:wrap;gap:0.3rem}
.wx-asmt-opt{font-family:var(--font-b);font-size:0.66rem;color:var(--tx3);border:1px solid var(--line);border-radius:6px;padding:0.18rem 0.45rem;display:inline-flex;align-items:center;gap:0.25rem}
.wx-asmt-opt.sel{color:#fff;background:color-mix(in srgb,var(--ac) 16%,transparent);border-color:color-mix(in srgb,var(--ac) 45%,var(--line))}
.wx-asmt-tick{color:var(--ac-hi);font-size:0.6rem}
.wx-asmt-matrow{display:flex;align-items:center;gap:0.6rem;flex-wrap:wrap}
.wx-asmt-mats{display:flex;gap:0.25rem}
.wx-asmt-mat{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:var(--font-m);font-size:0.64rem;color:var(--tx4);border:1px solid var(--line)}
.wx-asmt-mat.sel{color:#0b0b0d;background:var(--ac);border-color:var(--ac);font-weight:600}
.wx-asmt-matlbl{font-family:var(--font-d);font-size:0.74rem;font-weight:600;color:#fff;display:inline-flex;align-items:center}
.wx-asmt-conf{font-family:var(--font-m);font-size:0.55rem;color:var(--warn);font-weight:400;margin-left:0.35rem}
.wx-asmt-actions{display:flex;gap:0.4rem;margin-top:0.55rem}
.wx-asmt-approve{font-family:var(--font-d);font-size:0.7rem;font-weight:700;color:#0b0b0d;background:var(--ac);border-radius:7px;padding:0.34rem 0.75rem;cursor:pointer}
.wx-asmt-override{font-family:var(--font-d);font-size:0.7rem;font-weight:600;color:var(--tx2);border:1px solid var(--line);border-radius:7px;padding:0.34rem 0.7rem;cursor:pointer}
/* scout assessment analysis + SOC 2 extraction */
.wx-an-list{display:flex;flex-direction:column}
.wx-an-row{display:grid;grid-template-columns:auto 1fr;gap:0.55rem;align-items:start;padding:0.5rem 0;border-top:1px solid var(--line)}
.wx-an-row:first-child{border-top:none}
.wx-an-t{font-size:0.78rem;color:var(--tx2);line-height:1.45}
.wx-soc-doc{display:flex;gap:0.55rem;align-items:center;padding-bottom:0.6rem;border-bottom:1px solid var(--line);margin-bottom:0.4rem}
.wx-soc-doc svg{width:16px;height:16px;color:var(--ac-hi);flex-shrink:0}
.wx-soc-docname{font-family:var(--font-d);font-size:0.8rem;font-weight:600;color:#fff}
.wx-soc-list{display:flex;flex-direction:column}
.wx-soc-row{display:flex;align-items:center;gap:0.55rem;padding:0.42rem 0;border-top:1px solid var(--line)}
.wx-soc-row:first-child{border-top:none}
.wx-soc-n{font-size:0.76rem;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.wx-cols-fit{flex:0 0 auto}
.wx-an-score{display:flex;align-items:center;justify-content:space-between;gap:0.5rem;padding:0.45rem 0.65rem;background:rgba(255,255,255,0.02);border:1px solid var(--line);border-radius:9px;margin-bottom:0.3rem}
.wx-an-score > span:first-child{font-family:var(--font-m);font-size:0.56rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--tx4)}
.wx-an-scoreR{display:flex;align-items:baseline;gap:0.45rem}
.wx-an-scoreR b{font-family:var(--font-d);font-size:1.1rem;color:#fff;font-variant-numeric:tabular-nums}
.wx-an-delta{font-family:var(--font-m);font-size:0.6rem;color:var(--bad)}
.wx-soc-cov{display:flex;align-items:center;gap:0.55rem;margin-bottom:0.45rem}
.wx-soc-cov .wx-rb-bar{flex:1}
.wx-soc-cov-v{font-family:var(--font-m);font-size:0.62rem;color:var(--tx2);white-space:nowrap}

/* product-page CTA below the window */
.wx-cta{position:relative;z-index:1;margin-top:1.1rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;background:rgba(255,255,255,0.025);border:1px solid var(--line-2);border-radius:14px;padding:0.9rem 1.1rem;opacity:0;transform:translateY(10px);transition:.8s var(--ease) .4s}
.wx-section[data-active] .wx-cta{opacity:1;transform:none}
.wx-cta-l{display:flex;align-items:center;gap:0.8rem;min-width:0;flex:1}
.wx-cta-logo{width:38px;height:38px;flex-shrink:0;display:flex}
.wx-cta-tx{min-width:0}
.wx-cta-t{font-family:var(--font-d);font-size:0.95rem;font-weight:700;color:#fff;letter-spacing:-0.01em}
.wx-cta-s{font-size:0.8rem;color:var(--tx3);margin-top:0.1rem}
.wx-cta-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:0.45rem;font-family:var(--font-d);font-size:0.875rem;font-weight:700;color:#0b0b0d;border-radius:9px;padding:0.65rem 1.15rem;letter-spacing:-0.01em;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.wx-cta-btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px -8px rgba(0,0,0,0.7)}
@media(max-width:560px){.wx-cta-btn{width:100%;justify-content:center}}
/* monitoring — external posture cards (mirrors 3PRM Continuous Monitoring) */
.wx-kpi-sub{font-family:var(--font-m);font-size:0.6rem;margin-top:0.25rem}
.wx-mon-head{display:flex;align-items:baseline;gap:0.5rem;margin-top:0.1rem}
.wx-mon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0.7rem}
@media(max-width:900px){.wx-mon-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.wx-mon-grid{grid-template-columns:1fr}}
.wx-mon-card{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:0.7rem 0.8rem;display:flex;flex-direction:column;gap:0.55rem}
.wx-mon-h{display:flex;align-items:center;gap:0.55rem}
.wx-mon-meta{flex:1;min-width:0}
.wx-mon-nm{font-family:var(--font-d);font-weight:600;font-size:0.82rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-0.01em}
.wx-mon-upd{font-family:var(--font-m);font-size:0.55rem;color:var(--tx4)}
.wx-mon-sev{display:inline-flex;align-items:center;gap:0.35rem;font-family:var(--font-m);font-size:0.6rem}
.wx-mon-grades{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}
.wx-grade{border:1px solid var(--line);border-radius:6px;overflow:hidden;display:flex;flex-direction:column}
.wx-grade .k{font-family:var(--font-m);font-size:0.46rem;letter-spacing:0.03em;text-transform:uppercase;color:var(--tx4);text-align:center;padding:2px 0 1px;background:rgba(255,255,255,0.02)}
.wx-grade .g{font-family:var(--font-d);font-weight:700;font-size:0.78rem;text-align:center;padding:2px 0 3px;color:#0b0b0d}
.wx-mon-foot{display:flex;flex-wrap:wrap;gap:0.3rem 0.45rem;align-items:center;margin-top:auto}
.wx-mon-tag{font-family:var(--font-m);font-size:0.52rem;color:var(--bad);white-space:nowrap}
.wx-mon-ports{font-family:var(--font-m);font-size:0.52rem;color:var(--tx4);margin-left:auto}
/* scout vendors card grid */
.wx-vc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.7rem}
@media(max-width:1100px){.wx-vc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.wx-vc-grid{grid-template-columns:repeat(2,1fr)}}
.wx-vc{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:0.7rem 0.8rem;display:flex;flex-direction:column;gap:0.55rem}
.wx-vc-h{display:flex;align-items:center;gap:0.55rem}
.wx-vc-meta{flex:1;min-width:0}
.wx-vc-nm{font-family:var(--font-d);font-weight:600;font-size:0.82rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-0.01em}
.wx-vc-cat{font-family:var(--font-m);font-size:0.56rem;color:var(--tx4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-vc-tags{display:flex;flex-wrap:wrap;gap:0.3rem}
.wx-vc-tag{font-family:var(--font-m);font-size:0.56rem;border:1px solid currentColor;border-radius:5px;padding:0.08rem 0.36rem;opacity:0.95}
.wx-vc-la{font-family:var(--font-m);font-size:0.56rem;color:var(--tx4);margin-top:auto;padding-top:0.1rem}
/* command GRC hub tabs */
.wx-grc-tabs{display:flex;gap:1.1rem;border-bottom:1px solid var(--line);padding-bottom:0;margin-bottom:0.2rem}
.wx-grc-tab{font-family:var(--font-d);font-size:0.8rem;font-weight:600;color:var(--tx4);padding-bottom:0.5rem;cursor:pointer}
.wx-grc-tab.on{color:#fff;border-bottom:2px solid var(--ac)}
/* supply chain v2 */
.wx-sc-conc{display:flex;flex-wrap:wrap;gap:0.4rem 1rem;margin-top:0.35rem}
.wx-sc-concitem{font-family:var(--font-m);font-size:0.66rem;color:var(--tx3)}
.wx-sc-concitem b{color:var(--warn);font-weight:500}
.wx-cols3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0.7rem;align-items:start}
@media(max-width:900px){.wx-cols3{grid-template-columns:1fr}}
.wx-spl-row{display:flex;align-items:center;gap:0.55rem;padding:0.5rem 0.5rem;border-radius:8px;border:1px solid transparent}
.wx-spl-row.active{background:color-mix(in srgb,var(--ac) 10%,transparent);border-color:color-mix(in srgb,var(--ac) 35%,var(--line))}
.wx-spl-tx{flex:1;min-width:0}
.wx-spl-n{font-family:var(--font-d);font-size:0.78rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-spl-s{font-family:var(--font-m);font-size:0.56rem;color:var(--tx4)}
.wx-spl-warn{color:var(--warn);display:flex}.wx-spl-warn svg{width:13px;height:13px}
.wx-spd{display:flex;flex-direction:column;align-items:center;gap:0.3rem;text-align:center;padding:0.5rem}
.wx-spd-logo{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.04);border:1px solid var(--line)}
.wx-spd-logo svg{width:22px;height:22px}
.wx-spd-n{font-family:var(--font-d);font-weight:700;font-size:0.92rem;color:#fff}
.wx-spd-cat{font-family:var(--font-m);font-size:0.58rem;color:var(--tx4)}
.wx-spd-badge{font-family:var(--font-m);font-size:0.56rem;color:var(--warn);border:1px solid color-mix(in srgb,var(--warn) 40%,var(--line));border-radius:5px;padding:0.1rem 0.4rem;margin-top:0.25rem}
.wx-spd-used{font-family:var(--font-m);font-size:0.54rem;letter-spacing:0.1em;color:var(--tx4);margin-top:0.5rem}
.wx-casc{display:flex;align-items:center;gap:0.55rem;padding:0.42rem 0;border-top:1px solid var(--line)}
.wx-casc:first-child{border-top:none}
.wx-casc-n{flex:1;min-width:0;font-size:0.76rem;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-casc-sev{font-family:var(--font-m);font-size:0.6rem;border:1px solid currentColor;border-radius:5px;padding:0.06rem 0.36rem}
/* anvil findings v2 (deal-scoped) */
.wx-pend{display:flex;align-items:center;gap:0.7rem;padding:0.5rem 0.6rem;border:1px solid color-mix(in srgb,var(--ac) 22%,var(--line));border-radius:9px;background:color-mix(in srgb,var(--ac) 5%,transparent)}
.wx-pend-l{flex:1;min-width:0}
.wx-pend-top{display:flex;align-items:center;gap:0.45rem}
.wx-pend-src{font-family:var(--font-m);font-size:0.54rem;color:var(--tx4);border:1px solid var(--line);border-radius:4px;padding:0.04rem 0.3rem;white-space:nowrap}
.wx-pend-t{font-family:var(--font-d);font-size:0.78rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-0.01em}
.wx-pend-from{font-family:var(--font-m);font-size:0.58rem;color:var(--ac-hi);margin-top:0.2rem}
.wx-pend-act{display:flex;gap:0.3rem;flex-shrink:0}
.wx-pend-approve{font-family:var(--font-d);font-size:0.66rem;font-weight:700;color:#0b0b0d;background:var(--ac);border-radius:6px;padding:0.26rem 0.55rem;white-space:nowrap}
.wx-pend-edit{font-family:var(--font-d);font-size:0.66rem;font-weight:600;color:var(--tx2);border:1px solid var(--line);border-radius:6px;padding:0.26rem 0.5rem}
.wx-pend-reject{font-family:var(--font-d);font-size:0.66rem;font-weight:600;color:var(--bad);border:1px solid color-mix(in srgb,var(--bad) 40%,var(--line));border-radius:6px;padding:0.26rem 0.45rem}
.wx-fnd{display:grid;grid-template-columns:auto 1fr auto auto;gap:0.6rem;align-items:center;padding:0.46rem 0;border-top:1px solid var(--line)}
.wx-fnd:first-child{border-top:none}
.wx-fnd-tx{min-width:0}
.wx-fnd-t{font-size:0.78rem;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-fnd-src{font-family:var(--font-m);font-size:0.56rem;color:var(--tx3);border:1px solid var(--line);border-radius:4px;padding:0.06rem 0.34rem;white-space:nowrap}
/* anvil DD report */
.wx-rpt-top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding-bottom:0.7rem;border-bottom:1px solid var(--line);margin-bottom:0.1rem}
.wx-rpt-eyebrow{font-family:var(--font-m);font-size:0.56rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--ac-hi)}
.wx-rpt-title{font-family:var(--font-d);font-size:1.1rem;font-weight:700;color:#fff;margin-top:0.15rem}
.wx-rpt{display:grid;grid-template-columns:150px 1fr;gap:0.9rem;flex:1;min-height:0}
@media(max-width:760px){.wx-rpt{grid-template-columns:1fr}.wx-rpt-nav{display:none}}
.wx-rpt-nav{display:flex;flex-direction:column;gap:1px}
.wx-rpt-navi{font-size:0.72rem;color:var(--tx4);padding:0.32rem 0.5rem;border-radius:6px;border-left:2px solid transparent;cursor:pointer}
.wx-rpt-navi.on{color:#fff;background:rgba(255,255,255,0.04);border-left-color:var(--ac)}
.wx-rpt-body{min-width:0;display:flex;flex-direction:column;gap:0.7rem;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.14) transparent}
.wx-rpt-body::-webkit-scrollbar{width:7px}.wx-rpt-body::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.11);border-radius:4px}
.wx-rpt-sec{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:0.7rem 0.85rem}
.wx-rpt-h{font-family:var(--font-d);font-size:0.85rem;font-weight:700;color:#fff;display:flex;align-items:center;margin-bottom:0.5rem}
.wx-rpt-grade{margin-left:auto;font-family:var(--font-d);font-weight:700;color:var(--warn)}
.wx-rpt-p{font-size:0.76rem;color:var(--tx2);line-height:1.55;margin-bottom:0.7rem}
.wx-rpt-barwrap{display:flex;flex-direction:column;gap:0.45rem;margin-bottom:0.8rem}
.wx-rpt-bar{display:grid;grid-template-columns:170px 1fr auto;gap:0.6rem;align-items:center;font-size:0.7rem;color:var(--tx3)}
.wx-rpt-bar b{font-family:var(--font-d);color:#fff}
.wx-rpt-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0.6rem}
.wx-rpt-sv{font-family:var(--font-d);font-weight:700;font-size:1.15rem;color:#fff}
.wx-rpt-sk{font-family:var(--font-m);font-size:0.54rem;letter-spacing:0.04em;text-transform:uppercase;color:var(--tx4);margin-top:0.1rem}
.wx-rpt-stack{display:flex;height:8px;border-radius:5px;overflow:hidden;gap:1px;margin-bottom:0.5rem}
.wx-rpt-stack span{display:block}
.wx-rpt-leg{display:flex;flex-wrap:wrap;gap:0.4rem 0.9rem;margin-bottom:0.7rem}
.wx-rpt-legi{display:inline-flex;align-items:center;gap:0.35rem;font-family:var(--font-m);font-size:0.6rem;color:var(--tx3)}
.wx-rpt-ctls{display:grid;grid-template-columns:1fr 1fr;gap:0.2rem 1.2rem}
.wx-rpt-ctl{display:flex;align-items:center;gap:0.5rem;padding:0.3rem 0;border-top:1px solid var(--line);font-size:0.72rem}
.wx-rpt-ctlk{font-family:var(--font-d);font-weight:600;color:#fff;min-width:34px}
.wx-rpt-ctlv{color:var(--tx3);font-family:var(--font-m);font-size:0.62rem;flex:1}
.wx-rpt-gap{font-family:var(--font-m);font-size:0.56rem;color:var(--warn)}
.wx-rpt-kf{display:flex;align-items:center;gap:0.5rem;padding:0.4rem 0;border-top:1px solid var(--line)}
.wx-rpt-kfsrc{font-family:var(--font-m);font-size:0.54rem;color:var(--tx3);border:1px solid var(--line);border-radius:4px;padding:0.04rem 0.3rem;white-space:nowrap}
.wx-rpt-kft{flex:1;min-width:0;font-size:0.74rem;color:var(--tx2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wx-rpt-kfcat{font-family:var(--font-m);font-size:0.54rem;color:var(--tx4);white-space:nowrap}

@media(max-width:1180px){
  .wx-body{grid-template-columns:170px 1fr}
  .wx-aside{display:none}
}
@media(max-width:840px){
  .wx-body{grid-template-columns:1fr}
  .wx-nav{display:none}
  .wx-cols,.wx-cols-cmd{grid-template-columns:1fr}
  .wx-kanban{grid-template-columns:repeat(2,1fr)}
  .wx-search{display:none}
  .wx-stab-tg{display:none}
}
@media(max-width:560px){
  .wx-kpis{grid-template-columns:repeat(2,1fr)}
  .wx-grid{height:auto}
  .wx-scroll{overflow:visible}
}
@media(prefers-reduced-motion:reduce){
  .wx-win{opacity:1!important;transform:none!important}
  .wx-eyebrow,.wx-title,.wx-sub{opacity:1!important;transform:none!important}
  .wx-stagger{opacity:1!important;transform:none!important;animation:none!important}
  .wx-live-dot{animation:none}
}
