:root{
  /* Light theme — white background, dark text, modern & professional */
  --bg-0:#ffffff; --bg-1:#f5f7fb; --bg-2:#edf1f7;
  --panel:#ffffff; --panel-2:#ffffff;
  --line:#e4e8f1; --line-soft:#eef2f8;
  --txt:#0c1220; --txt-dim:#4a5568; --txt-faint:#7c869b;
  --amber:#10208c; --amber-soft:#3a4fc4; --amber-rgb:16,32,140; --teal:#0e9b8a;   /* primary accent is navy blue (matches the EMO logo) */
  --green:#0f9d6f; --yellow:#e08a0c; --red:#e5484d;
  --radius:14px;
  /* Whole-platform typeface: Aktiv Grotesk (renders where licensed/installed or via the Adobe Fonts kit in the HTML head); falls back to Inter — the closest free neo-grotesque. */
  --mono:'Aktiv Grotesk','Inter','Helvetica Neue',Arial,sans-serif;
  --sans:'Aktiv Grotesk','Inter','Helvetica Neue',Arial,sans-serif;
  --display:'Aktiv Grotesk','Inter','Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* accessibility: visible keyboard focus */
a:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible,[tabindex]:focus-visible,.nav-item:focus-visible,.unav-item:focus-visible,.crm-row:focus-visible,.cls-tab:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:6px}
body{background:var(--bg-0);color:var(--txt);font-family:var(--sans);line-height:1.55;min-height:100vh;-webkit-font-smoothing:antialiased;position:relative;overflow-x:hidden;font-variant-numeric:tabular-nums}
body::before{content:none}
body::after{content:none}

.app{position:relative;z-index:1;display:grid;grid-template-columns:288px 1fr;min-height:100vh}

/* header */
header.topbar{grid-column:1/-1;position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:18px;padding:13px 24px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand .mark{width:42px;height:42px;border-radius:11px;background:linear-gradient(140deg,var(--amber),#0a1566);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:17px;color:#ffffff;box-shadow:0 0 0 1px rgba(16,32,140,.4),0 8px 22px -8px rgba(16,32,140,.6);position:relative}
.brand .mark::after{content:"";position:absolute;inset:0;border-radius:11px;background:linear-gradient(160deg,rgba(255,255,255,.45),transparent 45%)}
.brand .wordmark{font-family:var(--display);font-weight:700;font-size:20px;letter-spacing:.06em}
.brand .wordmark b{color:var(--amber)}
.brand .sub{font-size:11.5px;color:var(--txt-dim)}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:11px;flex-wrap:wrap;justify-content:flex-end}
.chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;background:var(--panel);border:1px solid var(--line);font-family:var(--mono);font-size:11.5px;color:var(--txt-dim);white-space:nowrap}
.chip b{color:var(--txt)}
.chip.ok{border-color:rgba(52,211,153,.4);color:var(--green)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px var(--teal)}
.chip.ok .dot{background:var(--green);box-shadow:0 0 8px var(--green)}
.tr-status{font-family:var(--mono);font-size:11px;color:var(--teal);opacity:0;transition:opacity .25s;white-space:nowrap}
.tr-status.show{opacity:1}
.tr-status.err{color:var(--amber)}
.lang-wrap,.role-wrap{display:flex;align-items:center;gap:7px}
.lang-wrap svg,.role-wrap svg{width:15px;height:15px;stroke:var(--txt-faint);fill:none}
#lang,#role{background:var(--bg-1);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:7px 10px;font-family:var(--sans);font-size:12.5px;outline:none;cursor:pointer}
#lang:focus,#role:focus{border-color:var(--teal)}
#role{border-color:rgba(16,32,140,.3);color:var(--amber)}

/* sidebar */
aside.sidebar{border-right:1px solid var(--line);padding:18px 14px 40px;position:sticky;top:69px;align-self:start;height:calc(100vh - 69px);overflow-y:auto;background:var(--bg-1)}
.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.search-wrap{position:relative;margin-bottom:18px}
.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;stroke:var(--txt-faint);fill:none}
#search{width:100%;padding:11px 13px 11px 36px;background:var(--bg-1);border:1px solid var(--line);border-radius:10px;color:var(--txt);font-family:var(--sans);font-size:13.5px;outline:none;transition:border-color .2s,box-shadow .2s}
#search::placeholder{color:var(--txt-faint)}
#search:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(67,217,200,.12)}
.nav-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--txt-faint);margin:16px 6px 8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8.5px 11px;border-radius:9px;cursor:pointer;color:var(--txt-dim);font-size:13.5px;font-weight:500;border:1px solid transparent;transition:background .16s,color .16s,border-color .16s;user-select:none}
.nav-item:hover{background:var(--panel);color:var(--txt)}
.nav-item.active{background:linear-gradient(90deg,rgba(16,32,140,.14),rgba(16,32,140,.02));color:var(--txt);border-color:rgba(16,32,140,.32)}
.nav-item.active .glyph{color:var(--amber)}
.nav-item .glyph{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-family:var(--mono);font-size:12px;background:var(--bg-2);color:var(--txt-faint);border:1px solid var(--line-soft);flex-shrink:0}
.nav-item .count{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--txt-faint);background:var(--bg-2);padding:1px 7px;border-radius:999px;border:1px solid var(--line-soft)}
.nav-item.active .count{color:var(--amber);border-color:rgba(16,32,140,.3)}

/* main + headings */
main{padding:28px 34px 80px;min-width:0;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.view-head{margin-bottom:24px}
.view-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:7px}
.view-title{font-family:var(--display);font-size:30px;font-weight:700}
.view-desc{color:var(--txt-dim);font-size:14.5px;margin-top:8px;max-width:820px}
.back-btn{background:var(--bg-1);border:1px solid var(--line);color:var(--txt-dim);border-radius:8px;padding:6px 13px;font-family:var(--sans);font-size:13px;cursor:pointer;margin-bottom:14px;transition:border-color .2s,color .2s}
.back-btn:hover{border-color:var(--teal);color:var(--txt)}

/* stats */
.stats{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:22px}
.stat{background:var(--panel);border:none;border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;animation:fade .5s both;box-shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px -12px rgba(16,24,40,.12)}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--amber);opacity:0;transition:opacity .2s}
.stat:hover{transform:translateY(-4px);box-shadow:0 14px 34px -18px rgba(16,24,40,.22)}
.stat:hover::before{opacity:1}
.stat .v{font-family:var(--display);font-size:30px;font-weight:700;color:var(--amber);line-height:1}
.stat .l{font-size:12.5px;color:var(--txt-dim);margin-top:9px}

/* hero quote */
.hero-quote{position:relative;background:linear-gradient(110deg,rgba(67,217,200,.07),rgba(16,32,140,.03));border:1px solid rgba(67,217,200,.22);border-radius:var(--radius);padding:22px 24px 22px 56px;font-size:15.5px;color:var(--txt);margin-bottom:20px;line-height:1.6}
.hero-mark{position:absolute;left:18px;top:6px;font-family:var(--display);font-size:48px;color:var(--teal);opacity:.5}

/* panels */
.panel{background:var(--panel);border:none;border-radius:var(--radius);padding:22px;margin-bottom:20px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px -12px rgba(16,24,40,.12)}
.panel-head{display:flex;align-items:center;gap:11px;margin-bottom:18px;flex-wrap:wrap}
.panel-head h3{font-family:var(--display);font-size:17px;font-weight:600}
.panel-head .ico{width:9px;height:9px;border-radius:2px;background:var(--teal);box-shadow:0 0 9px var(--teal);flex-shrink:0}
.panel-head .tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);border:1px solid rgba(67,217,200,.3);border-radius:999px;padding:3px 9px;margin-left:auto}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}

/* build steps */
.steps{display:flex;flex-direction:column;gap:10px}
.step{display:flex;gap:13px;align-items:center;padding:12px 14px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px;transition:border-color .2s,transform .2s}
.step:hover{border-color:rgba(67,217,200,.35);transform:translateX(3px)}
.step .num{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--teal);background:rgba(67,217,200,.1);border:1px solid rgba(67,217,200,.28);border-radius:8px;padding:5px 9px;min-width:42px;text-align:center;flex-shrink:0}
.step-body{flex:1;min-width:0}
.step-t{font-weight:600;font-size:14px}
.tested{font-family:var(--mono);font-size:10px;color:var(--green);border:1px solid rgba(52,211,153,.4);border-radius:999px;padding:3px 9px;white-space:nowrap}

/* filenames + code */
.filename{font-family:var(--mono);font-size:11.5px;color:var(--teal);direction:ltr;unicode-bidi:isolate;word-break:break-all;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:7px;padding:6px 9px;display:inline-block}
.code,.schema-body,.md-pre{font-family:var(--mono);font-size:12.5px;line-height:1.7;color:#cdd8ee;background:var(--bg-0);border:1px solid var(--line);border-radius:10px;padding:15px 17px;overflow-x:auto;direction:ltr}
.code code,.schema-body code,.md-pre code{white-space:pre}
.arch-line{margin-top:12px;font-family:var(--mono);font-size:12px;color:var(--teal);background:rgba(67,217,200,.07);border:1px solid rgba(67,217,200,.22);border-radius:8px;padding:9px 12px;direction:ltr}
.note{font-size:13px;color:var(--txt-dim);margin-top:12px}

/* callouts */
.callout{margin-top:14px;padding:14px 16px;border-radius:10px;background:linear-gradient(100deg,rgba(67,217,200,.08),transparent);border:1px solid rgba(67,217,200,.22);font-size:13.5px;color:var(--txt-dim)}
.callout b{color:var(--teal)}
.amber-callout{background:linear-gradient(100deg,rgba(16,32,140,.08),transparent);border-color:rgba(16,32,140,.25);margin-bottom:18px}
.amber-callout b{color:var(--amber)}
.lane-note{padding:15px 18px;border-radius:12px;background:linear-gradient(100deg,rgba(67,217,200,.08),transparent);border:1px solid rgba(67,217,200,.22);font-size:13.5px;color:var(--txt-dim)}
.lane-note b{color:var(--teal)}
.route-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:15px;font-weight:600}
.route-pt{padding:7px 14px;border-radius:9px;background:rgba(var(--amber-rgb,37,99,235),.08);color:var(--txt)}
.route-arrow{color:var(--amber);font-weight:700;font-size:18px}
.ord-steps{display:flex;align-items:center;gap:0;margin:0 0 24px;flex-wrap:wrap}
.ord-step{display:flex;align-items:center;gap:9px}
.ord-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:700;background:var(--bg-2);color:var(--txt-faint);flex:0 0 auto}
.ord-step.done .ord-dot{background:var(--teal);color:#fff}
.ord-step.current .ord-dot{background:var(--amber);color:#fff;box-shadow:0 0 0 4px rgba(var(--amber-rgb,37,99,235),.16)}
.ord-lbl{font-size:13px;color:var(--txt-faint);white-space:nowrap}
.ord-step.done .ord-lbl,.ord-step.current .ord-lbl{color:var(--txt);font-weight:600}
.ord-conn{flex:1 1 28px;min-width:18px;height:2px;background:var(--bg-2);margin:0 10px}
.ord-conn.done{background:var(--teal)}
.ord-cancelled{padding:11px 15px;border-radius:10px;background:rgba(229,72,77,.08);color:var(--red);font-size:13.5px;font-weight:600;margin-bottom:18px}
.ship-prog{height:7px;border-radius:5px;background:var(--bg-2);overflow:hidden;margin:2px 0 6px}
.ship-prog-bar{height:100%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:5px;transition:width .4s}
.ship-prog-cap{font-size:12px;color:var(--txt-dim);margin-bottom:12px;font-weight:600}
.ship-list{display:flex;flex-direction:column;gap:2px}
.ship-row{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:8px;font-size:13px}
.ship-row.current{background:rgba(var(--amber-rgb,37,99,235),.07)}
.ship-dot{width:18px;height:18px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;background:var(--bg-2);color:var(--txt-faint)}
.ship-row.done .ship-dot{background:var(--teal);color:#fff}
.ship-row.current .ship-dot{background:var(--amber);color:#fff}
.ship-lbl{flex:1;color:var(--txt-faint)}
.ship-row.done .ship-lbl,.ship-row.current .ship-lbl{color:var(--txt);font-weight:600}
.ship-date{font-size:11px;color:var(--txt-faint)}
.contract-top{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:6px}
.doc-menu{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.doc-menu-lbl{font-size:12px;color:var(--txt-faint);font-weight:600}
.mk-pipe{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.mk-col{background:var(--bg-1);border-radius:12px;padding:12px;min-height:80px}
.mk-col-h{font-size:12.5px;font-weight:700;color:var(--txt);display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.mk-col-h span{font-family:var(--mono);font-size:11px;color:var(--teal);background:var(--panel);border-radius:6px;padding:2px 8px}
.mk-card{background:var(--panel);border-radius:9px;padding:9px 11px;margin-bottom:7px;box-shadow:0 1px 2px rgba(16,24,40,.05)}
.mk-card-t{font-size:12.5px;font-weight:600;color:var(--txt);line-height:1.3}
.mk-card-d{font-size:10.5px;color:var(--txt-faint);font-family:var(--mono);margin-top:3px}
.mk-feed-head{font-family:var(--mono);font-size:10.5px;color:var(--txt-faint);margin-bottom:10px;letter-spacing:.03em}
.tn-search-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.tn-q{flex:1;min-width:240px;background:var(--bg-1);border:1px solid var(--line);color:var(--txt);border-radius:10px;padding:10px 14px;font-family:var(--sans);font-size:14px;outline:none}
.tn-q:focus{border-color:var(--teal)}
@media(max-width:760px){.mk-pipe{grid-template-columns:1fr 1fr}}
/* SVG art (window.EMOArt) — admin + customer apps */
.emo-art{display:block;width:100%;height:100%}
/* PR & Media assistant */
.pr-fdesc{font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-top:8px}
.pr-draft{background:var(--bg-1);border:1px solid var(--line);border-radius:10px;padding:16px 18px;font-family:var(--mono);font-size:12.5px;line-height:1.62;color:var(--txt);white-space:pre-wrap;word-break:break-word;max-height:520px;overflow:auto;margin:0}
.pr-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.pr-empty{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;color:var(--txt-faint);font-size:13px;padding:30px 20px;line-height:1.55}
.pr-empty .emo-art{width:96px;height:96px;opacity:.9}
/* Leadership org dashboard */
.lead-team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.lead-card{background:var(--bg-1);border:1px solid var(--line);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;transition:border-color .15s,transform .15s}
.lead-card:hover{border-color:rgba(67,217,200,.4);transform:translateY(-2px)}
.lead-card-top{display:flex;align-items:flex-start;gap:12px}
.lead-num{font-family:var(--display);font-size:22px;font-weight:800;color:var(--amber);line-height:1;flex-shrink:0;width:30px}
.lead-title{font-family:var(--display);font-size:15px;font-weight:700;line-height:1.25}
.lead-domain{font-size:12px;color:var(--txt-dim);margin-top:3px;line-height:1.4}
.lead-kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:11px 13px}
.lead-kpi-v{font-family:var(--display);font-size:21px;font-weight:700;color:var(--teal)}
.lead-kpi-l{font-size:11px;color:var(--txt-faint);margin-top:2px}
.lead-views{display:flex;flex-wrap:wrap;gap:6px}
.lead-vchip{font-family:var(--mono);font-size:10px;color:var(--txt-dim);background:var(--panel);border:1px solid var(--line);border-radius:6px;padding:3px 8px}
/* Trade corridors (admin) */
.corrx-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px}
.corrx{background:var(--bg-1);border:1px solid var(--line);border-radius:14px;padding:18px;transition:border-color .15s,transform .15s}
.corrx:hover{border-color:rgba(67,217,200,.4);transform:translateY(-2px)}
.corrx.flag{border-color:rgba(16,32,140,.28);background:linear-gradient(135deg,rgba(16,32,140,.04),rgba(67,217,200,.04)),var(--bg-1)}
.corrx-h{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.corrx-art{width:46px;height:46px;flex-shrink:0}
.corrx-name{font-family:var(--display);font-size:16px;font-weight:700;line-height:1.2}
.corrx-comm{font-family:var(--mono);font-size:11px;color:var(--teal);margin-top:2px}
.corrx-route{font-family:var(--mono);font-size:12.5px;color:var(--txt);font-weight:600;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:8px 12px;margin-bottom:12px}
.corrx-route .ar{color:var(--teal);margin:0 4px}
.corrx-kv{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin-bottom:12px}
.cxkv{display:flex;flex-direction:column;gap:1px}
.cxk{font-size:10.5px;color:var(--txt-faint);text-transform:uppercase;letter-spacing:.03em}
.cxv{font-size:13px;color:var(--txt);font-weight:600}
.corrx-note{font-size:12.5px;color:var(--txt-dim);line-height:1.5;border-top:1px solid var(--line);padding-top:10px}
.lane-chip{display:inline-block;font-family:var(--mono);font-size:9.5px;font-weight:600;color:var(--teal);background:rgba(67,217,200,.1);border:1px solid rgba(67,217,200,.28);border-radius:6px;padding:1px 6px;margin-left:6px;white-space:nowrap;vertical-align:middle}
.corrx-orders{display:flex;gap:10px;margin:10px 0 0;padding-top:10px;border-top:1px dashed var(--line)}
.corrx-ord{flex:1;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:8px 6px}
.corrx-ord-v{font-family:var(--display);font-size:17px;font-weight:700;color:var(--teal)}
.corrx-ord-l{font-size:10px;color:var(--txt-faint);margin-top:1px}
.corrx.sel{border-color:var(--teal);box-shadow:0 0 0 1px rgba(67,217,200,.3)}
.corr-miles{display:flex;flex-direction:column;gap:0;margin-top:8px}
.corr-mile{display:flex;align-items:center;gap:10px;padding:7px 0;position:relative}
.corr-mile .cm-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0;border:2px solid var(--line);background:var(--panel)}
.corr-mile.done .cm-dot{background:var(--teal);border-color:var(--teal)}
.corr-mile.active .cm-dot{background:var(--amber);border-color:var(--amber);box-shadow:0 0 0 3px rgba(16,32,140,.12)}
.corr-mile .cm-t{font-size:13px;color:var(--txt)}
.corr-mile.todo .cm-t{color:var(--txt-faint)}
.corr-mile .cm-s{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--txt-faint)}
.corr-mile.done .cm-s{color:var(--teal)}
.corr-mile.active .cm-s{color:var(--amber)}
.corr-cps{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.corr-cp{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:9px;padding:8px 11px}
.corr-cp-n{font-size:13px;font-weight:600;color:var(--txt)}
.corr-cp-m{font-family:var(--mono);font-size:10.5px;color:var(--txt-faint)}
/* Route planner */
.route-legs{display:flex;flex-wrap:wrap;align-items:center;gap:6px;background:var(--bg-1);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.route-leg{display:flex;align-items:center;gap:6px}
.rl-node{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--txt);background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:6px 11px}
.rl-arrow{color:var(--teal);font-weight:700;margin:0 2px}
.route-cust{font-size:12.5px;color:var(--txt-dim);line-height:1.5;margin-top:4px}
.route-cust b{color:var(--txt)}
.emo-routemap{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.corrx-routemap{max-width:520px;margin:12px 0}
.sd-demand-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:9px;flex-wrap:wrap}
.sd-reach{font-size:11px;font-weight:600;color:var(--teal-ink,#0f766e);background:rgba(67,217,200,.12);border-radius:7px;padding:3px 8px;align-self:flex-start}
.reach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-top:10px}
.reach-card{background:var(--bg-1);border-radius:11px;padding:14px 16px;text-align:center}
.reach-card.support{background:rgba(67,217,200,.10)}
.reach-card.support .reach-n{color:var(--teal-ink,#0f766e)}
.reach-n{font-size:1.5rem;font-weight:800;color:var(--amber);letter-spacing:-.02em}
.reach-l{font-size:11px;color:var(--ink-soft);margin-top:2px;text-transform:uppercase;letter-spacing:.04em}
.reach-sub{font-size:11px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.05em;margin-top:14px}
.reach-sub:first-of-type{margin-top:4px}
.dem-result{margin-top:14px;border-radius:12px;padding:16px 18px;border:1px solid var(--line);background:var(--bg-1)}
.dem-result.over{border-color:rgba(181,71,8,.35);background:rgba(181,71,8,.06)}
.dem-result.under{border-color:rgba(6,118,71,.3);background:rgba(6,118,71,.06)}
.dem-big{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:var(--txt-dim)}
.dem-result.over .dem-big{color:#b54708}.dem-result.under .dem-big{color:#067647}
.dem-amt{font-family:var(--display);font-size:30px;font-weight:700;margin:4px 0 2px;letter-spacing:-.01em}
.dem-result.over .dem-amt{color:#b54708}.dem-result.under .dem-amt{color:#067647}
.dem-sub{font-size:12.5px;color:var(--txt-dim)}
.dc-build{background:var(--bg-1);border:1px solid var(--line);border-radius:11px;padding:6px 14px;margin-top:6px}
.dc-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:8px 0;font-size:13px;color:var(--txt-dim);border-bottom:1px solid var(--line-soft)}
.dc-row:last-child{border-bottom:none}
.dc-row span:last-child{font-family:var(--mono);font-weight:600;color:var(--txt)}
.dc-row.dc-total{font-weight:700;color:var(--txt)}
.dc-row.dc-total span:last-child{color:var(--amber);font-size:15px}
.ship-map{margin-bottom:10px}
.ship-map .emo-routemap{max-width:100%;border:1px solid var(--line);border-radius:12px}
.ship-eta{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--txt-dim);margin-bottom:12px}
.ship-eta-dot{width:8px;height:8px;border-radius:50%;background:var(--amber);box-shadow:0 0 0 0 rgba(16,32,140,.5);animation:newspulse 2s infinite}
@keyframes newspulse{0%{box-shadow:0 0 0 0 rgba(16,32,140,.45)}70%{box-shadow:0 0 0 7px rgba(16,32,140,0)}100%{box-shadow:0 0 0 0 rgba(16,32,140,0)}}
.sign-agree{display:flex;align-items:flex-start;gap:10px;margin-top:14px;font-size:12.5px;color:var(--txt-dim);line-height:1.5;cursor:pointer}
.sign-agree input{margin-top:3px;width:16px;height:16px;flex-shrink:0;accent-color:var(--teal)}
.sign-audit{margin-top:12px;background:var(--bg-1);border:1px solid var(--line);border-radius:11px;padding:13px 15px}
.sign-audit-h{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);font-weight:700;margin-bottom:8px}
/* Licensed Merchant catalogue (customer) */
.cat-licence{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,rgba(16,32,140,.06),rgba(67,217,200,.05));border:1px solid rgba(16,32,140,.16);border-radius:14px;padding:14px 18px;margin-bottom:20px}
.cat-licence-ic{width:46px;height:46px;flex-shrink:0}
.cat-licence-k{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;color:var(--amber);font-weight:700}
.cat-licence-v{font-size:14.5px;font-weight:600;color:var(--txt);margin-top:2px}
.cat-domain{margin-bottom:20px}
.cat-domain-h{display:flex;align-items:center;gap:12px;margin:18px 0 12px;padding-bottom:10px;border-bottom:2px solid var(--line)}
.cat-art{width:40px;height:40px;flex-shrink:0;display:block}
.cat-domain-ttl{font-family:var(--display);font-size:19px;font-weight:700;letter-spacing:-.01em}
.cat-domain-meta{font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-top:2px}
.cat-cat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:12px}
.cat-cat-h{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.cat-cat-ttl{font-family:var(--display);font-size:15.5px;font-weight:600}
.cat-cat-n{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--teal);background:var(--bg-1);border:1px solid var(--line);border-radius:7px;padding:4px 9px}
.cat-src{font-size:11px;font-weight:600;color:var(--teal-ink,#0f766e);background:rgba(67,217,200,.12);border-radius:7px;padding:4px 9px;white-space:nowrap}
.cat-prods{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:9px}
.cat-prod{background:var(--bg-1);border:1px solid var(--line);border-radius:10px;padding:11px 13px;cursor:pointer;transition:transform .15s,border-color .15s,background .15s}
.cat-prod:hover{border-color:rgba(67,217,200,.45);background:var(--bg-2);transform:translateY(-1px)}
.cat-prod:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.cat-prod-n{font-size:13px;font-weight:600;color:var(--txt)}
.cat-prod-m{font-family:var(--mono);font-size:10px;color:var(--txt-faint);margin-top:4px;display:flex;gap:6px;flex-wrap:wrap}
.cat-prod-m .cls{color:var(--amber)}
.cat-prod-m .cc{color:var(--teal)}
.cat-prod-cta{font-family:var(--mono);font-size:10px;color:var(--teal);margin-top:7px;font-weight:600}
/* Services hub (customer) — each capability sold standalone */
.svc-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.svc-card{display:grid;grid-template-columns:auto 1fr;gap:16px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px;transition:transform .15s,border-color .15s,box-shadow .15s}
.svc-card:hover{transform:translateY(-2px);border-color:rgba(67,217,200,.4);box-shadow:0 8px 24px -14px rgba(16,24,40,.2)}
.svc-card-art{width:60px;height:60px;flex-shrink:0}
.svc-card-tag{font-family:var(--mono);font-size:10px;letter-spacing:.05em;color:var(--amber);font-weight:700}
.svc-card-ttl{font-family:var(--display);font-size:17px;font-weight:600;margin-top:3px}
.svc-card-body p{font-size:13px;color:var(--txt-dim);line-height:1.55;margin:8px 0 0}
.svc-card-body .biz-chips{margin-top:10px}
.svc-card-foot{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.svc-card-foot .mini-btn{margin-left:auto}
.svc-badge{font-family:var(--mono);font-size:10px;font-weight:700;border-radius:20px;padding:4px 10px;letter-spacing:.02em}
.svc-badge.lic{color:var(--teal);background:rgba(67,217,200,.12);border:1px solid rgba(67,217,200,.3)}
.svc-badge.inc{color:var(--txt-dim);background:var(--bg-1);border:1px solid var(--line)}
.svc-badge.req{color:var(--amber);background:rgba(16,32,140,.06);border:1px solid rgba(16,32,140,.2)}
.svc-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.svc-price{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--teal);background:rgba(67,217,200,.1);border:1px solid rgba(67,217,200,.3);border-radius:8px;padding:3px 9px;white-space:nowrap}
.svc-basis{font-size:12px;color:var(--txt-dim);line-height:1.45;margin-top:8px}
.svc-depth{font-size:11px;font-weight:600;color:var(--teal-ink,#0f766e);background:rgba(67,217,200,.1);border-radius:7px;padding:4px 9px;margin-top:8px;display:inline-block}
.svc-pkgs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}
.svc-pkg{background:var(--bg-1);border:1px solid var(--line);border-radius:9px;padding:9px 10px;text-align:center}
.svc-pkg-n{font-size:11px;font-weight:700;color:var(--txt)}
.svc-pkg-p{font-family:var(--mono);font-size:12.5px;font-weight:700;color:var(--amber);margin:2px 0}
.svc-pkg-f{font-size:10px;color:var(--txt-faint);line-height:1.3}
@media(max-width:860px){.svc-cards{grid-template-columns:1fr}}
/* Merchant spec drill-down modal (customer) */
.umodal{position:fixed;inset:0;z-index:300;background:rgba(12,18,32,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px}
.umodal.show{display:flex}
.umodal-card{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:18px;max-width:540px;width:100%;padding:30px;box-shadow:0 30px 80px -20px rgba(16,24,40,.45);animation:umin .18s ease;max-height:88vh;overflow:auto}
@keyframes umin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.umodal-x{position:absolute;top:16px;right:16px;background:var(--bg-1);border:1px solid var(--line);border-radius:8px;width:30px;height:30px;cursor:pointer;color:var(--txt-dim);font-size:13px}
.umodal-art{width:64px;height:64px;margin-bottom:12px}
.umodal-sec{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--teal);font-weight:700}
.umodal-ttl{font-family:var(--display);font-size:23px;font-weight:700;margin:4px 0 8px;letter-spacing:-.01em}
.umodal-tags{display:flex;gap:8px;font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-bottom:12px;flex-wrap:wrap}
.umodal-tags .cls{color:var(--amber);font-weight:700}
.umodal-tags .cc{color:var(--teal)}
.umodal-tags .ctrl{color:#b54708}
.umodal-desc{font-size:13.5px;color:var(--txt-dim);line-height:1.55;margin:0 0 16px}
.umodal-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 18px;margin-bottom:14px}
.umodal-grid>div{display:flex;flex-direction:column;gap:2px}
.umk{font-size:11px;color:var(--txt-faint);text-transform:uppercase;letter-spacing:.03em}
.umv{font-size:13.5px;color:var(--txt);font-weight:600}
.umodal-note{font-size:12.5px;color:var(--txt-dim);background:var(--bg-1);border-radius:10px;padding:12px 14px;line-height:1.5;margin-bottom:6px}
.umodal-cta{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.proc-meds{display:flex;flex-direction:column;gap:7px;max-height:520px;overflow-y:auto;padding-right:4px}
.proc-med{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg-1);border-radius:9px;padding:9px 12px}
.proc-med-n{font-size:13.5px;font-weight:600;color:var(--txt)}
.proc-med-m{font-family:var(--mono);font-size:10.5px;color:var(--txt-faint);margin-top:3px;display:flex;gap:7px;flex-wrap:wrap}
.proc-med-m .cls{color:var(--amber)}
.proc-med-m .cc{color:var(--teal)}
.proc-subtotal{display:flex;justify-content:space-between;align-items:center;margin-top:10px;padding:10px 14px;border-radius:10px;background:rgba(var(--amber-rgb,37,99,235),.06);font-size:14px}
.proc-subtotal b{font-size:18px;color:var(--amber)}
.rx-bars{display:flex;flex-direction:column;gap:9px}
.rx-bar-row{display:grid;grid-template-columns:1fr 2.2fr auto;align-items:center;gap:12px}
.rx-bar-l{font-size:12.5px;color:var(--txt-dim)}
.rx-bar{height:9px;border-radius:5px;background:var(--bg-2);overflow:hidden}
.rx-bar-f{height:100%;background:var(--amber);border-radius:5px;transition:width .4s}
.rx-bar-n{font-family:var(--mono);font-size:12px;color:var(--txt);min-width:36px;text-align:right}
@media(max-width:760px){.rx-bar-row{grid-template-columns:1.2fr 1.5fr auto}}
.conf-notice{display:flex;gap:10px;align-items:flex-start;padding:12px 16px;border-radius:11px;background:rgba(180,35,24,.06);border:1px solid rgba(180,35,24,.22);color:#922;font-size:13px;line-height:1.5;margin:0 0 18px}
.conf-notice b{color:#b42318}
.price-mode{display:inline-block;font-size:12px;font-weight:700;padding:5px 12px;border-radius:8px}
.price-mode.formula{background:rgba(var(--amber-rgb,37,99,235),.1);color:var(--amber)}
.price-mode.fixed{background:rgba(14,155,138,.1);color:var(--teal)}

/* invariants */
.inv-grid{display:flex;flex-direction:column;gap:9px}
.inv{display:flex;align-items:center;gap:12px;padding:11px 14px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;font-size:14px;transition:border-color .2s,background .2s}
.inv:hover{border-color:rgba(16,32,140,.3);background:var(--panel-2)}
.inv-n{font-family:var(--mono);font-size:10.5px;color:var(--txt-faint);min-width:22px}
.inv-list{display:flex;flex-direction:column;gap:10px}
.inv-full{display:flex;align-items:flex-start;gap:12px;padding:13px 15px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px}
.inv-full .inv-t{font-weight:600;font-size:14px}
.inv-full .inv-d{font-size:12.5px;color:var(--txt-dim);margin-top:3px}
.light{width:11px;height:11px;border-radius:50%;flex-shrink:0;margin-top:3px}
.light.g{background:var(--green);box-shadow:0 0 9px var(--green)}
.light.a{background:var(--yellow);box-shadow:0 0 9px var(--yellow)}
.light.r{background:var(--red);box-shadow:0 0 9px var(--red)}

/* layers */
.stack{display:flex;flex-direction:column;gap:9px}
.layer{display:flex;align-items:center;gap:16px;padding:15px 18px;border-radius:12px;background:var(--panel-2);border:1px solid var(--line);transition:transform .2s,border-color .2s;animation:fade .5s both}
.layer:hover{transform:translateX(5px);border-color:rgba(67,217,200,.4)}
.layer-x{width:44px;height:44px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;font-family:var(--display);font-size:18px;font-weight:700;background:var(--bg-2);border:1px solid var(--line);color:var(--teal)}
.layer-t{font-weight:600;font-size:15px}
.layer-d{font-size:12.5px;color:var(--txt-dim);margin-top:2px}
.layer.core{background:linear-gradient(100deg,rgba(16,32,140,.13),rgba(16,32,140,.02));border-color:rgba(16,32,140,.4)}
.layer.core .layer-x{color:var(--amber);border-color:rgba(16,32,140,.45)}
.layer.base{background:linear-gradient(100deg,rgba(100,113,142,.13),transparent)}
.layer.base .layer-x{color:var(--txt-dim)}
.layer-arrow{text-align:center;color:var(--txt-faint);font-size:12px;line-height:.4}

/* data tables */
.md-table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:11px}
.data-table,.md-table{width:100%;border-collapse:collapse;font-size:13px;min-width:520px}
.data-table th,.md-table th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);background:var(--bg-1);padding:11px 14px;border-bottom:1px solid var(--line)}
.data-table td,.md-table td{padding:11px 14px;border-bottom:1px solid var(--line-soft);color:var(--txt-dim);vertical-align:top}
.data-table tr:last-child td,.md-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:rgba(67,217,200,.03)}
.td-strong{color:var(--txt);font-weight:600}
.td-dim{color:var(--txt-faint);font-size:12.5px}
.autonomy-pill{font-family:var(--mono);font-size:10.5px;color:var(--amber);background:rgba(16,32,140,.08);border:1px solid rgba(16,32,140,.28);border-radius:999px;padding:3px 9px;white-space:nowrap}
.result{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11.5px;font-weight:600}
.result.r{color:var(--red)}.result.a{color:var(--yellow)}.result .light{margin-top:0}

/* autonomy */
.auto-list{display:flex;flex-direction:column;gap:11px}
.auto-row{display:flex;align-items:flex-start;gap:12px;font-size:13.5px;color:var(--txt-dim)}
.auto-row b{color:var(--txt)}
.auto-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:4px}
.auto-dot.l0{background:var(--green);box-shadow:0 0 8px var(--green)}
.auto-dot.l1{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}
.auto-dot.l2{background:var(--red);box-shadow:0 0 8px var(--red)}

/* mirror model */
.no-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.no-card{display:flex;gap:13px;align-items:flex-start;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:15px 16px;transition:border-color .2s}
.no-card:hover{border-color:rgba(248,113,113,.35)}
.no-k{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;background:rgba(248,113,113,.12);color:var(--red);font-weight:700;flex-shrink:0}
.no-t{font-weight:600;font-size:14.5px}
.no-d{font-size:12.5px;color:var(--txt-dim);margin-top:4px}
.arche-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.arche{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px;border-left:3px solid var(--teal)}
.arche-t{font-weight:600;font-size:14.5px;color:var(--teal)}
.arche-d{font-size:13px;color:var(--txt-dim);margin-top:6px}
.flow{display:flex;flex-direction:column;gap:8px}
.flow-step{display:flex;gap:13px;align-items:center;padding:11px 14px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px}
.flow-step.gate{border-color:rgba(16,32,140,.35);background:linear-gradient(100deg,rgba(16,32,140,.06),transparent)}
.flow-n{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:12px;font-weight:600;background:var(--bg-2);color:var(--teal);border:1px solid var(--line);flex-shrink:0}
.flow-step.gate .flow-n{color:var(--amber);border-color:rgba(16,32,140,.4)}
.flow-t{font-size:13.5px}

/* schema cards */
.schema-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.schema{background:var(--bg-1);border:1px solid var(--line);border-radius:11px;overflow:hidden}
.schema-name{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--amber);padding:11px 15px;background:rgba(16,32,140,.06);border-bottom:1px solid var(--line)}
.schema-body{border:none;border-radius:0;background:transparent;font-size:11.5px;margin:0}
.kv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px;margin-top:14px}
.kv{display:flex;justify-content:space-between;gap:12px;align-items:center;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:8px;padding:9px 12px}
.kv-k{font-family:var(--mono);font-size:12px;color:var(--txt-dim)}
.kv-v{font-family:var(--mono);font-size:12px;color:var(--teal);font-weight:600;text-align:right}

/* compliance levels */
.level-list{display:flex;flex-direction:column;gap:12px}
.level{display:flex;gap:14px;align-items:flex-start;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:15px 16px}
.level-n{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;font-family:var(--display);font-weight:700;background:var(--bg-2);color:var(--teal);border:1px solid var(--line);flex-shrink:0}
.level-k{font-weight:600;font-size:14.5px}
.level-d{font-size:13px;color:var(--txt-dim);margin-top:5px}

/* state machine */
.state-machine{display:flex;flex-direction:column}
.sm-phase{display:flex;gap:16px}
.sm-rail{display:flex;flex-direction:column;align-items:center}
.sm-dot{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-weight:600;font-size:14px;background:var(--bg-2);color:var(--teal);border:1px solid rgba(67,217,200,.4);flex-shrink:0;z-index:1}
.sm-phase:not(:last-child) .sm-rail::after{content:"";width:2px;flex:1;background:var(--line);margin:4px 0}
.sm-phase.hot .sm-dot{color:var(--amber);border-color:rgba(16,32,140,.5);background:rgba(16,32,140,.08)}
.sm-body{padding-bottom:20px;flex:1;min-width:0}
.sm-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:5px}
.sm-t{font-weight:600;font-size:15px}
.sm-state{font-family:var(--mono);font-size:10.5px;color:var(--green);background:rgba(52,211,153,.08);border:1px solid rgba(52,211,153,.3);border-radius:6px;padding:2px 8px}
.sm-phase.hot .sm-state{color:var(--amber);background:rgba(16,32,140,.08);border-color:rgba(16,32,140,.3)}
.sm-d{font-size:13px;color:var(--txt-dim)}
.legend{display:flex;flex-wrap:wrap;gap:10px}
.legend-chip{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--txt-dim);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:8px;padding:7px 11px}
.legend-k{font-family:var(--mono);font-weight:600;color:var(--teal)}

/* chips */
.chip-row{display:flex;flex-wrap:wrap;gap:8px}
.chip-tag{font-family:var(--mono);font-size:12px;color:var(--txt-dim);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:999px;padding:5px 12px}

/* commodity grids */
.sector-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}
.sector{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--txt-dim);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:9px;padding:11px 13px}
.sector-n{font-family:var(--mono);font-size:11px;color:var(--amber);flex-shrink:0}
.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:10px}
.service{display:flex;gap:11px;align-items:center;font-size:13px;color:var(--txt-dim);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:9px;padding:11px 13px}
.service-n{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--teal);background:var(--bg-2);border:1px solid var(--line-soft);flex-shrink:0}

/* class library */
.cls-tabs{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:18px}
.cls-tab{display:inline-flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line);color:var(--txt-dim);border-radius:10px;padding:9px 14px;font-family:var(--sans);font-size:13px;cursor:pointer;transition:border-color .18s,color .18s,background .18s}
.cls-tab:hover{color:var(--txt);border-color:rgba(67,217,200,.35)}
.cls-tab.active{background:linear-gradient(90deg,rgba(16,32,140,.14),rgba(16,32,140,.02));border-color:rgba(16,32,140,.4);color:var(--txt)}
.cls-n{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-family:var(--mono);font-weight:600;background:var(--bg-2);color:var(--teal);border:1px solid var(--line-soft)}
.cls-tab.active .cls-n{color:var(--amber);border-color:rgba(16,32,140,.4)}
.param-table{display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);border-radius:11px;overflow:hidden}
.param-row{display:grid;grid-template-columns:160px 1fr;gap:0;background:var(--bg-1)}
.param-row:nth-child(odd){background:var(--panel-2)}
.param-k{font-family:var(--mono);font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--teal);padding:13px 16px;border-right:1px solid var(--line)}
.param-v{font-size:13.5px;color:var(--txt-dim);padding:13px 16px}

/* params engines */
.param-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.param-engine{margin-bottom:0}
.param-engine .kv-grid{grid-template-columns:1fr;margin-top:0}

/* roadmap */
.phases{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.phase{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px 18px;position:relative;transition:transform .2s,border-color .2s;animation:fade .5s both}
.phase:hover{transform:translateY(-4px);border-color:rgba(67,217,200,.35)}
.phase.done{border-color:rgba(52,211,153,.4);background:linear-gradient(170deg,rgba(52,211,153,.08),transparent)}
.phase-ph{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--teal)}
.phase.done .phase-ph{color:var(--green)}
.phase-t{font-family:var(--display);font-size:18px;font-weight:600;margin:6px 0 4px}
.phase-badge{position:absolute;top:16px;right:16px;font-family:var(--mono);font-size:10px;color:var(--green);border:1px solid rgba(52,211,153,.45);border-radius:999px;padding:3px 9px}
.phase ul{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:7px}
.phase li{font-size:13px;color:var(--txt-dim);padding-left:16px;position:relative}
.phase li::before{content:"";position:absolute;left:0;top:8px;width:5px;height:5px;border-radius:50%;background:var(--teal)}
.phase.done li::before{background:var(--green)}

/* doc cards */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.card{text-align:left;background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden;cursor:pointer;font-family:inherit;color:inherit;transition:transform .2s,border-color .2s,box-shadow .2s}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--amber),var(--teal));opacity:0;transition:opacity .2s}
.card:hover{transform:translateY(-5px);border-color:rgba(67,217,200,.4);box-shadow:0 18px 44px -24px rgba(0,0,0,.95)}
.card:hover::before{opacity:1}
.card-top{display:flex;align-items:flex-start;gap:10px}
.card-t{font-family:var(--display);font-size:15.5px;font-weight:600;line-height:1.3;flex:1}
.card-d{font-size:13px;color:var(--txt-dim);flex:1}
.card .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;padding-top:4px}
.tag-pill{font-size:11px;color:var(--txt-dim);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:999px;padding:2px 9px}
.ver{font-family:var(--mono);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;padding:3px 8px;border-radius:999px;flex-shrink:0;white-space:nowrap;font-weight:600}
.ver.latest{color:var(--green);background:rgba(52,211,153,.1);border:1px solid rgba(52,211,153,.4)}
.ver.new{color:var(--amber);background:rgba(16,32,140,.1);border:1px solid rgba(16,32,140,.4)}
.ver.old{color:var(--txt-faint);background:var(--bg-2);border:1px solid var(--line)}
.search-summary{font-family:var(--mono);font-size:12px;color:var(--txt-faint);margin-bottom:16px}
.search-summary b{color:var(--teal)}
.empty{padding:60px 20px;text-align:center;color:var(--txt-faint);font-size:15px}
.empty-big{font-size:40px;margin-bottom:12px;opacity:.5}

/* reader */
.reader-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:10px}
.reader-translate{background:rgba(67,217,200,.08);border:1px solid rgba(67,217,200,.32);color:var(--teal);border-radius:8px;padding:7px 13px;font-family:var(--sans);font-size:12.5px;cursor:pointer;transition:background .2s}
.reader-translate:hover{background:rgba(67,217,200,.16)}
.reader-translate:disabled{opacity:.6;cursor:default}
.reader{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:30px 34px}
.reader-loading,.reader-error{color:var(--txt-dim);font-size:14px;text-align:center;padding:30px}
.reader-error b{color:var(--amber)}
.reader.rtl-content .md{direction:rtl;text-align:right}
.md{font-size:14.5px;line-height:1.75;color:var(--txt)}
.md .md-h{font-family:var(--display);font-weight:600;margin:26px 0 12px;line-height:1.3}
.md h2.md-h{font-size:24px;color:var(--amber);border-bottom:1px solid var(--line);padding-bottom:10px}
.md h3.md-h{font-size:19px;color:var(--teal)}
.md h4.md-h{font-size:16px}
.md h5.md-h,.md h6.md-h{font-size:14px;color:var(--txt-dim)}
.md p{margin:11px 0;color:var(--txt-dim)}
.md strong{color:var(--txt);font-weight:600}
.md .md-list{margin:11px 0;padding-left:24px;color:var(--txt-dim);display:flex;flex-direction:column;gap:6px}
.reader.rtl-content .md-list{padding-left:0;padding-right:24px}
.md .md-list li{font-size:14px}
.md .md-sub{margin:6px 0;opacity:.92}
.md code{font-family:var(--mono);font-size:12.5px;color:var(--teal);background:var(--bg-0);border:1px solid var(--line-soft);border-radius:5px;padding:1px 6px}
.md .md-pre{margin:14px 0;direction:ltr;text-align:left}
.md .md-pre code{border:none;background:transparent;padding:0;color:#cdd8ee}
.md blockquote{margin:14px 0;padding:12px 18px;border-left:3px solid var(--teal);background:rgba(67,217,200,.05);border-radius:0 8px 8px 0;color:var(--txt-dim);font-style:italic}
.reader.rtl-content blockquote{border-left:none;border-right:3px solid var(--teal);border-radius:8px 0 0 8px}
.md .md-table-wrap{margin:16px 0}
.md .md-hr{border:none;border-top:1px solid var(--line);margin:22px 0}
.md a{color:var(--teal)}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--panel-2);border:1px solid var(--line);color:var(--txt);padding:12px 20px;border-radius:10px;font-size:13.5px;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:100;box-shadow:0 14px 40px -16px rgba(0,0,0,.9)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* footer */
footer{grid-column:1/-1;border-top:1px solid var(--line);padding:18px 34px;font-family:var(--mono);font-size:11.5px;color:var(--txt-faint);display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* RTL adjustments for whole-page translation */
html[dir="rtl"] .data-table th,html[dir="rtl"] .md-table th{text-align:right}
html[dir="rtl"] .arche{border-left:none;border-right:3px solid var(--teal)}
html[dir="rtl"] .card{text-align:right}

/* responsive */
@media(max-width:980px){
  .app{grid-template-columns:1fr}
  aside.sidebar{position:static;height:auto;border-right:none;border-bottom:1px solid var(--line)}
  main{padding:24px 18px 60px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid-2,.no-grid,.arche-grid,.param-grid{grid-template-columns:1fr}
  .phases{grid-template-columns:1fr 1fr}
  .cards{grid-template-columns:1fr}
  .topbar .sub{display:none}
}
@media(max-width:560px){
  .stats,.phases{grid-template-columns:1fr}
  .param-row{grid-template-columns:1fr}
  .param-k{border-right:none;border-bottom:1px solid var(--line)}
  .chip.deck{display:none}
  .view-title{font-size:24px}
  .reader{padding:20px 18px}
  .runner-bar{flex-direction:column;align-items:flex-start}
}

/* ============ operational platform ============ */
.mark-img,.mark-svg{width:46px;height:46px;border-radius:10px;background:#fff;padding:3px;flex-shrink:0;box-shadow:0 0 0 1px var(--line),0 6px 18px -8px rgba(0,0,0,.7)}
.ops-kpi{grid-template-columns:repeat(5,1fr)}
.mini-btn{background:var(--bg-2);border:1px solid var(--line);color:var(--txt-dim);border-radius:8px;padding:7px 12px;font-family:var(--sans);font-size:12.5px;cursor:pointer;transition:border-color .18s,color .18s,background .18s;white-space:nowrap}
.mini-btn:hover{color:var(--txt);border-color:rgba(67,217,200,.4)}
.mini-btn.solid{background:rgba(67,217,200,.12);border-color:rgba(67,217,200,.4);color:var(--teal);font-weight:600}
.mini-btn.solid:hover{background:rgba(67,217,200,.22)}
.mini-btn.ghost{background:transparent}
.mini-btn.wide{width:100%;padding:11px;margin-top:4px}
.soon{font-family:var(--mono);font-size:10.5px;color:var(--txt-faint);border:1px solid var(--line);border-radius:999px;padding:3px 9px}
.arrow{color:var(--teal)}

/* phase navigator */
.ph-nav .phase{display:flex;flex-direction:column}
.ph-mods{display:flex;flex-direction:column;gap:9px;margin-top:14px}
.ph-mod{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;padding:12px 13px}
.ph-mod.off{opacity:.6}
.ph-mod-top{display:flex;align-items:center;gap:9px}
.ph-mod-dot{width:9px;height:9px;border-radius:50%;background:var(--txt-faint);flex-shrink:0}
.ph-mod-dot.on{background:var(--green);box-shadow:0 0 8px var(--green)}
.ph-mod-n{font-weight:600;font-size:13.5px}
.ph-mod-d{font-size:12px;color:var(--txt-dim);margin:6px 0 9px}

/* score bar */
.scorebar{display:inline-block;width:60px;height:6px;border-radius:3px;background:var(--bg-2);border:1px solid var(--line-soft);margin-right:8px;vertical-align:middle;overflow:hidden}
.scorebar>span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--amber))}

/* KRI */
.kri{margin-bottom:12px}
.kri-top{display:flex;justify-content:space-between;font-size:13px;color:var(--txt-dim);margin-bottom:5px}
.kri-bar{height:8px;border-radius:4px;background:var(--bg-2);border:1px solid var(--line-soft);overflow:hidden}
.kri-bar>span{display:block;height:100%;background:var(--teal)}
.kri-bar>span.over{background:var(--red)}

/* mandate console */
.mandate-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mctl{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--txt-dim)}
.mctl input,.mctl select{background:var(--bg-1);border:1px solid var(--line);color:var(--txt);border-radius:8px;padding:8px 10px;font-family:var(--mono);font-size:13px;outline:none}
.mctl input:focus,.mctl select:focus{border-color:var(--teal)}
.mctl select{appearance:none;-webkit-appearance:none;cursor:pointer;padding-right:30px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237a8499' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 11px center}
.mctl select:hover{border-color:var(--teal)}
.mctl optgroup{font-weight:700;color:var(--txt);font-style:normal}
.mctl optgroup option{font-weight:400;color:var(--txt)}

/* audit log */
.audit{display:flex;flex-direction:column;gap:1px;font-family:var(--mono)}
.audit-row{display:grid;grid-template-columns:46px 78px 1fr auto;gap:10px;align-items:center;padding:8px 10px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:7px;font-size:12px}
.audit-seq{color:var(--txt-faint)}
.audit-kind{font-size:10px;font-weight:600;letter-spacing:.05em;text-align:center;border-radius:5px;padding:2px 6px;color:var(--teal);background:rgba(67,217,200,.1);border:1px solid rgba(67,217,200,.3)}
.audit-kind.k-lock,.audit-kind.k-settle{color:var(--green);background:rgba(52,211,153,.1);border-color:rgba(52,211,153,.35)}
.audit-kind.k-gate,.audit-kind.k-mandate{color:var(--amber);background:rgba(16,32,140,.1);border-color:rgba(16,32,140,.35)}
.audit-kind.k-risk,.audit-kind.k-invariant{color:var(--red);background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.35)}
.audit-msg{color:var(--txt-dim)}
.audit-t{color:var(--txt-faint)}

/* portal offer */
.inq-form{display:flex;flex-direction:column;gap:12px}
.offer{border:1px solid var(--line);border-radius:12px;padding:18px;background:var(--bg-1);min-height:160px}
.offer.ok{border-color:rgba(52,211,153,.35);background:linear-gradient(160deg,rgba(52,211,153,.06),transparent)}
.offer.no{border-color:rgba(248,113,113,.3)}
.offer-h{display:flex;justify-content:space-between;align-items:center;font-family:var(--display);font-weight:600;font-size:15px;margin-bottom:14px}
.offer-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.offer-grid>div{display:flex;flex-direction:column;gap:3px}
.ol{font-size:11px;color:var(--txt-faint);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em}
.ov{font-size:14.5px;color:var(--txt);font-weight:600}

/* deal runner */
.runner-bar{display:flex;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.runner-bar select{background:var(--bg-1);border:1px solid var(--line);color:var(--txt);border-radius:9px;padding:9px 12px;font-family:var(--sans);font-size:13.5px;outline:none}
.runner-bar select:focus{border-color:var(--teal)}
.runner-meta{font-size:13px;color:var(--txt-dim)}
.sm-phase.done .sm-dot{color:var(--green);border-color:rgba(52,211,153,.45);background:rgba(52,211,153,.08)}
.gate-tag{font-family:var(--mono);font-size:9.5px;color:var(--amber);border:1px solid rgba(16,32,140,.4);border-radius:5px;padding:2px 6px}
.ledger{display:flex;flex-direction:column;gap:8px}
.ledger-row{display:flex;justify-content:space-between;font-size:13.5px;color:var(--txt-dim);padding:10px 12px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:8px}
.ledger-row.inv.ok{border-color:rgba(52,211,153,.4);color:var(--green)}
.ledger-row.inv.bad{border-color:rgba(248,113,113,.4);color:var(--red)}

@media(max-width:980px){.ops-kpi{grid-template-columns:repeat(2,1fr)}.mandate-grid,.offer-grid{grid-template-columns:1fr}.audit-row{grid-template-columns:40px 70px 1fr;gap:8px}.audit-t{display:none}}

/* ============ phase-deepening modules ============ */
.nav-sublabel{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--txt-faint);margin:12px 8px 5px;opacity:.85}
.nav-domain{display:flex;flex-direction:column;gap:3px;background:linear-gradient(135deg,rgba(16,32,140,.07),rgba(67,217,200,.06));border:1px solid rgba(16,32,140,.18);border-radius:10px;padding:9px 11px;margin:2px 2px 10px}
.nav-domain-k{font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--amber);font-weight:700}
.nav-domain-v{font-size:12px;color:var(--txt);font-weight:600;line-height:1.3}
.pos{color:var(--green)}.neg{color:var(--red)}
.md-list.md-sub,.md-list{list-style:disc}

/* market intelligence */
.bench-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.bench{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px;padding:13px 15px;border-left:3px solid var(--line)}
.bench.up{border-left-color:var(--green)}.bench.down{border-left-color:var(--red)}
.bench-k{font-size:12px;color:var(--txt-dim);display:flex;justify-content:space-between;gap:6px}
.bench-src{font-family:var(--mono);font-size:9.5px;color:var(--txt-faint)}
.bench-px{font-family:var(--display);font-size:24px;font-weight:700;margin:6px 0 2px}
.bench.up .bench-px{color:var(--txt)}.bench-chg{font-family:var(--mono);font-size:11.5px}
.bench.up .bench-chg{color:var(--green)}.bench.down .bench-chg{color:var(--red)}
.stream-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:14px}
.stream{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:15px 16px}
.stream-h{display:flex;align-items:center;gap:9px;font-weight:600;font-size:14px;margin-bottom:11px}
.stream-g{font-size:16px}
.signal-list{display:grid;grid-template-columns:1fr 1fr;gap:2px 22px}
@media(max-width:760px){.signal-list{grid-template-columns:1fr}}
.signal{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;color:var(--txt-dim);padding:6px 0}
.sig-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}
.sig-dot.info{background:var(--teal)}.sig-dot.watch{background:var(--yellow)}.sig-dot.alert{background:var(--red);box-shadow:0 0 7px var(--red)}

/* CRM 360 */
.crm-row{cursor:pointer}
.crm-row.sel td{background:rgba(16,32,140,.06)}
.c360{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.c360-h{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px}
.c360-n{font-family:var(--display);font-weight:600;font-size:17px}
.c360-sub{font-family:var(--mono);font-size:11px;color:var(--txt-faint)}
.c360-block{margin-top:14px}
.c360-l{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.c360-ul{list-style:none;display:flex;flex-direction:column;gap:5px}
.c360-ul li{font-size:12.5px;color:var(--txt-dim);padding-left:14px;position:relative}
.c360-ul li::before{content:"›";position:absolute;left:0;color:var(--teal)}

/* doc-intel checks */
.chk{font-family:var(--mono);font-weight:700}
.chk.ok{color:var(--green)}.chk.no{color:var(--red)}
.data-table tr.disc td{background:rgba(248,113,113,.05)}

/* pricing P&L */
.pnl-strip{display:flex;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.pnl-box{flex:1;min-width:140px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px;padding:14px 16px}
.pnl-l{font-size:12px;color:var(--txt-dim)}
.pnl-v{display:block;font-family:var(--display);font-size:24px;font-weight:700;color:var(--green);margin-top:5px}
.fin-col{margin-top:12px}
.fin-h{font-size:11px;font-weight:700;color:var(--txt-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.fin-chips{display:flex;flex-wrap:wrap;gap:7px}
.fin-chip{font-size:12px;color:var(--ink);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:8px;padding:4px 10px}
.fin-chip b{color:var(--amber);margin-left:3px;font-weight:700}

/* contracts */
.contract{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.contract-h{font-family:var(--display);font-weight:600;font-size:15px;color:var(--amber);margin-bottom:14px}
.contract .kv-grid{grid-template-columns:1fr}
.contract-law{font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-top:12px;border-top:1px solid var(--line-soft);padding-top:10px}

/* R&D tracks */
.rd-grid{display:flex;flex-direction:column;gap:13px}
.rd{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;padding:12px 14px}
.rd-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.rd-d{font-weight:600;font-size:13.5px}
.trl{font-family:var(--mono);font-size:11px;color:var(--teal)}
.rd-bar{height:6px;border-radius:3px;background:var(--bg-2);border:1px solid var(--line-soft);overflow:hidden;margin-bottom:7px}
.rd-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--amber))}
.rd-ms{font-size:12px;color:var(--txt)}

/* partner scorecards */
.ps-grid{display:flex;flex-direction:column;gap:11px}
.pscore{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;padding:12px 14px}
.ps-top{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:13.5px;margin-bottom:8px}
.ps-tier{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;padding:2px 8px;border-radius:999px}
.ps-tier.preferred{color:var(--green);border:1px solid rgba(52,211,153,.4);background:rgba(52,211,153,.1)}
.ps-tier.approved{color:var(--teal);border:1px solid rgba(67,217,200,.4);background:rgba(67,217,200,.1)}
.ps-tier.watch{color:var(--yellow);border:1px solid rgba(251,191,36,.4);background:rgba(251,191,36,.1)}
.ps-bar{position:relative;height:18px;border-radius:5px;background:var(--bg-2);border:1px solid var(--line-soft);overflow:hidden;margin-bottom:8px}
.ps-bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--green))}
.ps-bar>b{position:absolute;right:8px;top:0;line-height:18px;font-family:var(--mono);font-size:11px;color:var(--txt)}
.ps-dims{display:flex;flex-wrap:wrap;gap:6px;font-family:var(--mono);font-size:10.5px;color:var(--txt-faint)}
.ps-dims span{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:6px;padding:2px 7px}

/* ============ relationships / lifecycle / legal / treasury ============ */
.audit-kind.k-opp{color:var(--teal);background:rgba(67,217,200,.1);border-color:rgba(67,217,200,.3)}
.audit-kind.k-sign,.audit-kind.k-board{color:var(--amber);background:rgba(16,32,140,.1);border-color:rgba(16,32,140,.35)}

/* relationship 360 */
.rel-kpi{display:grid;grid-template-columns:repeat(2,1fr);gap:9px;margin:6px 0 4px}
.rel-kpi>div{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:9px;padding:9px 11px;display:flex;flex-direction:column;gap:3px}
.rk-l{font-size:11px;color:var(--txt-faint)}
.rk-v{font-family:var(--display);font-weight:700;font-size:17px}
.rel-row{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:8px;margin-bottom:6px;font-size:12.5px}
.rel-id{font-family:var(--mono);font-size:11px;color:var(--txt-faint);min-width:64px}
.rel-prod{flex:1;font-weight:600}
.rel-val{font-family:var(--mono);font-size:11.5px;color:var(--teal)}

/* lifecycle stage pills */
.stage-pill{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;padding:2px 8px;border-radius:999px;border:1px solid var(--line);color:var(--txt-dim);white-space:nowrap}
.st-market_scan,.st-marketing,.st-qualified{color:var(--teal);border-color:rgba(67,217,200,.35);background:rgba(67,217,200,.08)}
.st-negotiation,.st-matched,.st-compliance{color:var(--amber);border-color:rgba(16,32,140,.35);background:rgba(16,32,140,.08)}
.st-locked,.st-settlement,.st-delivered{color:#c4b5fd;border-color:rgba(167,139,250,.35);background:rgba(167,139,250,.08)}
.st-completed{color:var(--green);border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08)}

/* engagement lifecycle kanban */
.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px}
.kanban::-webkit-scrollbar{height:9px}.kanban::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}
.kcol{flex:0 0 178px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:11px}
.kcol-h{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--txt);margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--line-soft)}
.kcol-phase{font-family:var(--mono);font-size:9px;color:var(--txt-faint);border:1px solid var(--line);border-radius:4px;padding:1px 4px}
.kcol-n{margin-left:auto;font-family:var(--mono);font-size:10.5px;color:var(--txt-faint);background:var(--bg-2);border-radius:999px;padding:1px 7px}
.kcard{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:9px;padding:9px 10px;margin-bottom:8px;border-left:3px solid var(--teal)}
.kcard.deal{border-left-color:#a78bfa}
.kc-prod{font-weight:600;font-size:12.5px}
.kc-party{font-size:11px;color:var(--txt-dim);margin:2px 0 6px}
.kc-foot{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:10.5px;color:var(--txt-faint)}
.kc-side{padding:1px 6px;border-radius:5px;background:var(--bg-2);border:1px solid var(--line-soft)}
.kc-side.deal{color:#c4b5fd}
.kempty{color:var(--txt-faint);font-size:11px;text-align:center;padding:8px 0;opacity:.5}

/* onboarding / authorization */
.auth-grid{display:flex;flex-direction:column;gap:10px}
.auth-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:9px;font-size:13.5px}

@media(max-width:980px){.rel-kpi{grid-template-columns:1fr}}

/* orchestration / escalation center */
.esc-list{display:flex;flex-direction:column;gap:9px}
.esc-row{display:flex;align-items:center;gap:13px;padding:13px 15px;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px}
.esc-row.done{opacity:.6}
.esc-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.esc-dot.a{background:var(--yellow);box-shadow:0 0 8px var(--yellow)}
.esc-dot.r{background:var(--red);box-shadow:0 0 8px var(--red)}
.esc-dot.g{background:var(--green)}
.esc-body{flex:1;min-width:0}
.esc-l{font-weight:600;font-size:14px}
.esc-h{font-size:12px;color:var(--txt-dim);margin-top:2px}
.esc-n{font-family:var(--display);font-weight:700;font-size:20px;color:var(--amber);min-width:28px;text-align:center}
.esc-row.done .esc-n{color:var(--green)}
.esc-ok{font-family:var(--mono);font-size:10.5px;color:var(--green);border:1px solid rgba(52,211,153,.4);border-radius:999px;padding:3px 9px}

/* order desk */
.od-side{display:flex;gap:9px;margin-bottom:14px}
.od-side .mini-btn{flex:1}
/* widened Order Desk: form full-width, proposal stacked below (point 9) */
.od-deck{display:flex;flex-direction:column;gap:16px}
@media(min-width:880px){.od-deck .mandate-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}}
.od-proposal-below{margin-top:0}
.od-proposal-below .offer.empty{min-height:0;padding:16px 18px}
/* graphical buyer / seller selector (point 10) */
.od-sidesel{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:16px}
@media(max-width:560px){.od-sidesel{grid-template-columns:1fr}}
.od-sidecard{display:flex;align-items:center;gap:12px;text-align:left;padding:13px 15px;border:1.5px solid var(--line);border-radius:13px;background:var(--bg-1);cursor:pointer;position:relative;transition:border-color .15s,background .15s,box-shadow .15s;font-family:inherit;width:100%}
.od-sidecard:hover{border-color:var(--txt-faint)}
.od-sidecard-ic{flex:0 0 auto;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:20px;font-weight:800;line-height:1;background:rgba(122,132,153,.12);color:var(--txt-dim);transition:background .15s,color .15s}
.od-sidecard-x{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.od-sidecard-t{font-weight:700;font-size:14px;color:var(--txt)}
.od-sidecard-t em{font-style:normal;font-weight:600;font-size:10.5px;color:var(--txt-faint);text-transform:uppercase;letter-spacing:.5px}
.od-sidecard-s{font-size:11.5px;color:var(--txt-faint);line-height:1.3}
.od-sidecard-tick{flex:0 0 auto;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:11px;font-weight:800;color:#fff;background:var(--line);opacity:0;transform:scale(.6);transition:opacity .15s,transform .15s,background .15s}
.od-sidecard.buy.active{border-color:var(--teal);background:rgba(14,155,138,.06);box-shadow:0 0 0 3px rgba(14,155,138,.1)}
.od-sidecard.buy.active .od-sidecard-ic{background:var(--teal);color:#fff}
.od-sidecard.buy.active .od-sidecard-tick{background:var(--teal);opacity:1;transform:scale(1)}
.od-sidecard.sell.active{border-color:var(--amber);background:rgba(16,32,140,.05);box-shadow:0 0 0 3px rgba(16,32,140,.09)}
.od-sidecard.sell.active .od-sidecard-ic{background:var(--amber);color:#fff}
.od-sidecard.sell.active .od-sidecard-tick{background:var(--amber);opacity:1;transform:scale(1)}
.od-tag{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--teal);background:rgba(67,217,200,.07);border:1px solid rgba(67,217,200,.22);border-radius:8px;padding:7px 11px;margin:12px 0}
.prop-stack{display:flex;flex-direction:column;gap:14px}
.prop-card{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.prop-h{font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--amber);margin-bottom:12px}
.prop-card .kv-grid{grid-template-columns:1fr 1fr;margin-top:0}
.prop-card .callout{margin-top:12px}
@media(max-width:980px){.prop-card .kv-grid{grid-template-columns:1fr}}

/* compliance screening report */
.scr{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.scr-h{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.scr-n{font-family:var(--display);font-weight:600;font-size:16px}
.scr-block{margin-top:13px}
.scr-lists{display:flex;flex-direction:column;gap:6px}
.scr-list{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--txt-dim);background:var(--bg-2);border:1px solid var(--line-soft);border-radius:7px;padding:7px 11px}
.scr-ubo{display:flex;justify-content:space-between;font-size:12.5px;background:var(--bg-2);border:1px solid var(--line-soft);border-radius:7px;padding:7px 11px;margin-bottom:5px}
.scr-ubo.bad{border-color:rgba(248,113,113,.45);color:var(--red)}

/* price build-up + sensitivity */
.buildup{display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.bu-row{display:flex;justify-content:space-between;font-size:13px;color:var(--txt-dim);padding:10px 13px;background:var(--bg-1)}
.bu-row:nth-child(even){background:var(--panel-2)}
.bu-row.strong{color:var(--txt);font-weight:600;background:rgba(67,217,200,.06)}
.sens{display:flex;align-items:flex-end;gap:12px;height:160px;padding:10px 6px}
.sens-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;gap:6px}
.sens-d{font-family:var(--mono);font-size:11px;color:var(--txt-faint)}
.sens-bar{width:100%;flex:1;display:flex;align-items:flex-end;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:6px;overflow:hidden}
.sens-bar>span{width:100%;background:linear-gradient(180deg,var(--teal),rgba(67,217,200,.4));border-radius:6px 6px 0 0}
.sens-bar>span.neg{background:linear-gradient(180deg,var(--red),rgba(248,113,113,.4))}
.sens-v{font-family:var(--mono);font-size:11px;color:var(--txt)}

/* market sparkline + opportunity list */
.spark{display:flex;align-items:flex-end;gap:2px;height:40px;margin:8px 0}
.spark>span{flex:1;background:var(--line);border-radius:1px;min-height:3px}
.bench.up .spark>span{background:rgba(52,211,153,.45)}
.bench.down .spark>span{background:rgba(248,113,113,.45)}
.spark>span.last{background:var(--amber)}
.rel-list{display:flex;flex-direction:column;gap:7px}

/* R&D enriched */
.rd-grid.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.rd.big{padding:15px 16px}
.rd-sub{font-family:var(--mono);font-size:11px;color:var(--txt-dim);margin:6px 0 8px}
.ms{display:flex;flex-direction:column;gap:5px;margin:10px 0}
.ms-step{display:flex;align-items:center;gap:9px;font-size:12px;color:var(--txt-faint)}
.ms-step .ms-dot{width:8px;height:8px;border-radius:50%;background:var(--line);flex-shrink:0}
.ms-step.done{color:var(--txt-dim)}.ms-step.done .ms-dot{background:var(--green)}
.ms-step.active{color:var(--amber)}.ms-step.active .ms-dot{background:var(--amber);box-shadow:0 0 7px var(--amber)}

/* partner monitoring */
.pscore.alert{border-color:rgba(248,113,113,.4)}
.ps-mon{display:flex;justify-content:space-between;gap:10px;font-size:11px;margin-top:9px;padding-top:8px;border-top:1px solid var(--line-soft)}
@media(max-width:980px){.rd-grid.two{grid-template-columns:1fr}}

/* deal dossier */
.dossier-head{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:linear-gradient(120deg,rgba(67,217,200,.06),transparent);border:1px solid var(--line);border-radius:12px;padding:15px 18px;margin-bottom:18px}
.dossier-head .c360-n{font-family:var(--display);font-weight:700;font-size:18px}
.dossier-head .c360-sub{font-size:12.5px;color:var(--txt-dim)}
.dossier-badges{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-left:auto}
.dz-grid{display:flex;flex-direction:column;gap:10px}
.dz-mini{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:10px;padding:12px 14px}
.dz-h{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--amber);margin-bottom:6px}
.dz-kv{font-size:12.5px;color:var(--txt-dim);margin-top:3px}

/* ============ user-centric app ============ */
.user-app{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}
.user-top{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:22px;padding:13px 30px;background:rgba(255,255,255,.88);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.user-nav{display:flex;gap:6px;margin-left:8px}
.unav-item{padding:8px 14px;border-radius:9px;color:var(--txt-dim);font-size:14px;font-weight:500;cursor:pointer;transition:background .16s,color .16s;user-select:none}
.unav-item:hover{background:var(--panel);color:var(--txt)}
.unav-item.active{background:linear-gradient(90deg,rgba(16,32,140,.16),rgba(16,32,140,.02));color:var(--txt)}
.user-right{margin-left:auto;display:flex;align-items:center;gap:11px}
.ccy-ico{font-family:var(--mono);color:var(--txt-faint)}
.admin-link{font-family:var(--mono);font-size:12px;color:var(--txt-faint);text-decoration:none;border:1px solid var(--line);border-radius:8px;padding:7px 11px}
.admin-link:hover{color:var(--teal);border-color:rgba(67,217,200,.3)}
.user-app>main{flex:1;max-width:1180px;width:100%;margin:0 auto;padding:30px 30px 70px}
.user-app>footer{max-width:1180px;width:100%;margin:0 auto}

/* hero */
.hero{position:relative;border:none;border-radius:18px;padding:42px 40px;margin-bottom:24px;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.04),0 8px 26px -14px rgba(16,24,40,.12);
  background:radial-gradient(700px 300px at 90% -20%,rgba(16,32,140,.06),transparent 60%),radial-gradient(600px 320px at -5% 120%,rgba(67,217,200,.05),transparent 60%),var(--panel)}
.hero-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--teal);margin-bottom:14px}
.hero-h{font-family:var(--display);font-size:38px;font-weight:700;line-height:1.1;max-width:760px}
.hero-p{font-size:16px;color:var(--txt-dim);margin-top:16px;max-width:680px;line-height:1.6}
.hero-cta{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}
.hero-cta .mini-btn{padding:12px 20px;font-size:14px}
.vp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.vp{background:var(--panel);border:none;border-radius:14px;padding:20px;box-shadow:0 1px 2px rgba(16,24,40,.04),0 6px 20px -12px rgba(16,24,40,.10)}
.vp-g{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:18px;background:var(--bg-2);color:var(--amber);border:1px solid var(--line);margin-bottom:12px}
.vp-t{font-family:var(--display);font-weight:600;font-size:15px}
.vp-d{font-size:13px;color:var(--txt-dim);margin-top:7px;line-height:1.5}
.usnap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px}
.uc-lane-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.uc-lane{display:flex;gap:12px;align-items:center;background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:12px 14px}
.uc-lane-art{flex:0 0 64px;width:64px;height:48px;border-radius:8px;overflow:hidden;display:block}
.uc-lane-art svg{width:100%;height:100%;display:block}
.uc-lane-b{flex:1;min-width:0}
.uc-lane-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.uc-lane-cmd{font-weight:700;color:var(--ink);font-size:14px}
.uc-lane-route{font-size:13px;color:var(--teal-ink,#0f766e);font-weight:600;margin-top:3px}
.uc-lane-meta{font-size:11px;color:var(--ink-soft);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* actionable trade-corridor lanes — clickable → Order Desk, with live data */
.uc-lane-act{align-items:flex-start;cursor:pointer;transition:transform .18s,box-shadow .2s,border-color .2s}
.uc-lane-act .uc-lane-art{margin-top:2px}
.uc-lane-act:hover{transform:translateY(-2px);border-color:var(--teal);box-shadow:var(--shadow-md,0 8px 20px -10px rgba(16,24,40,.18))}
.uc-lane-act:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.uc-lane-live{display:flex;flex-wrap:wrap;gap:5px 7px;margin-top:9px}
.uc-lane-live .ull{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--txt-dim);background:var(--panel);border:1px solid var(--line-soft);border-radius:7px;padding:3px 8px;white-space:nowrap;font-family:var(--mono)}
.uc-lane-live .ull i{font-style:normal;color:var(--teal);font-size:11px}
.uc-lane-cta{margin-top:9px;font-size:12px;font-weight:700;color:var(--teal);display:inline-flex;align-items:center;gap:4px;opacity:.85;transition:gap .18s,opacity .18s}
.uc-lane-act:hover .uc-lane-cta{opacity:1;gap:7px}
@media(max-width:720px){.uc-lane-grid{grid-template-columns:1fr}}
.usnap{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px;padding:13px 15px}
.usnap.sub{border-color:var(--teal);box-shadow:inset 0 0 0 1px rgba(67,217,200,.25)}
.usnap-k{font-size:12px;color:var(--txt-dim)}
.usnap-v{font-family:var(--display);font-size:20px;font-weight:700;margin-top:5px}
.usnap-u{font-size:11px;color:var(--txt-faint);font-family:var(--mono)}
.usnap-c{font-family:var(--mono);font-size:11.5px;margin-top:3px}
@media(max-width:900px){
  .vp-grid{grid-template-columns:1fr 1fr}.hero-h{font-size:28px}
  .user-top{flex-wrap:wrap;gap:10px 14px;padding:11px 16px}
  .user-nav{order:3;width:100%;margin-left:0;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:3px;flex-wrap:nowrap}
  .user-nav .unav-item{white-space:nowrap;flex:0 0 auto}
  .user-right{order:2;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}
}
@media(max-width:560px){
  .vp-grid{grid-template-columns:1fr}
  .notif-panel{width:calc(100vw - 26px);right:-6px;max-width:none}
}

/* customer contract + e-seal */
.ai-comment{font-size:13.5px;line-height:1.6;color:var(--txt);background:linear-gradient(110deg,rgba(67,217,200,.08),transparent);border:1px solid rgba(67,217,200,.25);border-radius:10px;padding:14px}
.ai-sub{font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-bottom:8px}
.seal{display:flex;align-items:center;gap:14px;background:linear-gradient(110deg,rgba(52,211,153,.1),transparent);border:1px solid rgba(52,211,153,.4);border-radius:12px;padding:16px}
.seal-badge{width:84px;height:84px;border-radius:50%;border:2px dashed var(--green);color:var(--green);display:grid;place-items:center;text-align:center;font-family:var(--mono);font-size:10px;font-weight:700;flex-shrink:0;line-height:1.3}
.seal-t{font-family:var(--display);font-weight:600;font-size:15px;color:var(--green)}
.seal-d{font-size:12px;color:var(--txt-dim);margin-top:4px}
.exec-lock{display:flex;align-items:flex-start;gap:14px;background:linear-gradient(110deg,rgba(16,32,140,.1),transparent);border:1px solid rgba(16,32,140,.4);border-radius:12px;padding:16px}
.exec-lock-badge{width:74px;height:74px;border-radius:50%;border:2px dashed var(--amber);color:var(--amber);display:grid;place-items:center;text-align:center;font-family:var(--mono);font-size:10px;font-weight:700;flex-shrink:0;line-height:1.3}
.exec-lock-t{font-family:var(--display);font-weight:600;font-size:15px;color:var(--amber)}
.exec-lock-d{font-size:12.5px;color:var(--txt-dim);margin-top:5px;line-height:1.55}
.exec-lock-cta{display:flex;gap:9px;margin-top:11px;flex-wrap:wrap}

/* client business profile */
.biz-head{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;align-items:flex-start;margin-bottom:14px}
.biz-focus{font-family:var(--display);font-size:16px;font-weight:600;color:var(--txt)}
.biz-desc{font-size:13px;color:var(--txt-dim);margin-top:5px;line-height:1.5;max-width:560px}
.biz-tier{text-align:right;display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.biz-badge{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-radius:7px;padding:4px 10px;border:1px solid var(--line)}
.biz-badge.enterprise{color:var(--amber);background:rgba(16,32,140,.1);border-color:rgba(16,32,140,.35)}
.biz-badge.pro{color:var(--teal);background:rgba(67,217,200,.1);border-color:rgba(67,217,200,.35)}
.biz-badge.basic{color:var(--txt-dim)}
.biz-meta{font-family:var(--mono);font-size:11px;color:var(--txt-faint)}
.biz-row{display:flex;gap:12px;align-items:flex-start;padding:9px 0;border-top:1px solid var(--line-soft)}
.biz-k{font-size:12px;color:var(--txt-faint);min-width:80px;padding-top:3px}
.biz-chips{display:flex;gap:6px;flex-wrap:wrap}
.biz-chip{font-size:12px;color:var(--txt);background:var(--bg-1);border:1px solid var(--line);border-radius:7px;padding:4px 10px}
.biz-chip.alt{color:var(--teal);border-color:rgba(67,217,200,.3)}
/* opportunities */
.opp-mini-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}
.opp-mini{background:var(--bg-1);border:1px solid var(--line);border-radius:10px;padding:12px}
.opp-mini-t{display:block;font-size:13.5px;font-weight:600;color:var(--txt)}
.opp-mini-m{display:block;font-family:var(--mono);font-size:10.5px;color:var(--amber);margin-top:4px}
.cap-wrap{display:flex;align-items:center;gap:18px;justify-content:space-between;flex-wrap:wrap}
.cap-lvl{font-family:var(--display);font-size:22px;font-weight:700;color:var(--teal)}
.cap-head{font-size:13.5px;color:var(--txt-dim);margin-top:3px}
.cap-meter{flex:1;min-width:160px;height:9px;border-radius:6px;background:var(--bg-1);border:1px solid var(--line-soft);overflow:hidden}
.cap-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--teal),var(--amber))}
.opp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.opp-card{background:var(--bg-1);border:none;border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:6px}
.opp-sec{font-family:var(--mono);font-size:10.5px;color:var(--teal);letter-spacing:.05em;text-transform:uppercase}
.opp-mer{font-family:var(--display);font-size:15px;font-weight:600;color:var(--txt)}
.opp-why{font-size:12.5px;color:var(--txt-dim);line-height:1.5;flex:1}
.opp-card .mini-btn{margin-top:6px}
.proj{background:var(--bg-1);border:none;border-radius:12px;padding:16px;margin-bottom:10px}
.proj-h{display:flex;justify-content:space-between;gap:12px;align-items:baseline;flex-wrap:wrap}
.proj-t{font-family:var(--display);font-size:15.5px;font-weight:600;color:var(--txt)}
.proj-type{font-family:var(--mono);font-size:10.5px;color:var(--bg);background:var(--amber);border-radius:5px;padding:3px 8px;white-space:nowrap}
.proj-meta{font-family:var(--mono);font-size:11px;color:var(--txt-faint);margin-top:6px}
.proj-why{font-size:13px;color:var(--txt-dim);margin-top:8px;line-height:1.5}
.proj .mini-btn{margin-top:12px}

/* notifications / alerts */
.notif-wrap{position:relative}
.notif-bell{position:relative;width:38px;height:38px;border-radius:9px;background:var(--bg-1);border:1px solid var(--line);color:var(--txt-dim);display:grid;place-items:center;cursor:pointer;transition:color .15s,border-color .15s}
.notif-bell:hover{color:var(--txt);border-color:var(--teal)}
.notif-bell svg{width:18px;height:18px}
.notif-badge{position:absolute;top:-5px;right:-5px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--red);color:#fff;font-family:var(--mono);font-size:10px;font-weight:700;display:grid;place-items:center;border:2px solid var(--bg-0)}
.notif-panel{position:absolute;top:46px;right:0;width:340px;max-height:440px;overflow:auto;background:var(--panel-2);border:1px solid var(--line);border-radius:14px;box-shadow:0 24px 60px -20px rgba(0,0,0,.85);z-index:120;display:none}
.notif-panel.show{display:block}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel-2)}
.notif-head span{font-family:var(--display);font-weight:600;font-size:14px}
.notif-readall{background:none;border:none;color:var(--teal);font-family:var(--sans);font-size:12px;cursor:pointer}
.notif-list{padding:6px}
.notif-item{display:flex;gap:11px;align-items:flex-start;padding:11px 12px;border-radius:10px;cursor:pointer;position:relative;transition:background .15s}
.notif-item:hover{background:var(--bg-1)}
.notif-item.unread{background:rgba(67,217,200,.05)}
.notif-ic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;font-size:13px;flex-shrink:0;background:var(--bg-2);border:1px solid var(--line);color:var(--txt-dim)}
.notif-ic.ok{color:var(--green);border-color:rgba(52,211,153,.4)}
.notif-ic.warn{color:var(--amber);border-color:rgba(16,32,140,.4)}
.notif-ic.bad{color:var(--red);border-color:rgba(248,113,113,.4)}
.notif-ic.info{color:var(--teal);border-color:rgba(67,217,200,.4)}
.notif-c{flex:1;min-width:0}
.notif-t{font-size:13px;font-weight:600;color:var(--txt)}
.notif-b{font-size:12px;color:var(--txt-dim);margin-top:2px;line-height:1.4}
.notif-at{font-family:var(--mono);font-size:10px;color:var(--txt-faint);margin-top:4px}
.notif-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);flex-shrink:0;margin-top:6px}
.notif-empty{padding:30px 16px;text-align:center;color:var(--txt-faint);font-size:13px}

/* activity / audit timeline */
.act-feed{display:flex;flex-direction:column;gap:7px}
.act-row{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--bg-1);border-radius:9px}
.act-k{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border-radius:5px;padding:3px 0;flex-shrink:0;width:84px;text-align:center;color:var(--txt-dim);background:var(--bg-2)}
.act-k.kyc{color:var(--amber);background:rgba(37,99,235,.1)}
.act-k.ticket{color:var(--teal);background:rgba(67,217,200,.12)}
.act-k.advisory{color:var(--yellow);background:rgba(224,138,12,.12)}
.act-k.order{color:var(--green);background:rgba(15,157,111,.12)}
.act-k.deal{color:var(--amber);background:rgba(37,99,235,.1)}
.act-c{flex:1;min-width:0}
.act-t{font-size:13px;font-weight:600;color:var(--txt)}
.act-d{font-size:12px;color:var(--txt-dim);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.act-meta{font-family:var(--mono);font-size:11px;color:var(--txt-faint);flex-shrink:0;text-align:right;white-space:nowrap}
@media(max-width:760px){.act-meta{display:none}}
.drop2{border:1.5px dashed var(--line);border-radius:11px;padding:22px;text-align:center;color:var(--txt-faint);font-size:13px;cursor:pointer;background:var(--bg-1);transition:border-color .15s,color .15s;margin-top:6px}
.drop2:hover{border-color:rgba(67,217,200,.45);color:var(--txt-dim)}
.drop2 .br{color:var(--teal)}
.user-top .admin-link.active{color:var(--teal);border-color:rgba(67,217,200,.4)}
.empty-cell{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;padding:26px 16px;color:var(--txt-faint);font-size:14px;text-align:center}
.empty-cell span{font-size:20px}
.empty-cell.big{flex-direction:column;gap:14px;padding:34px 16px}
.empty-art{width:76px;height:76px}
.hero-deco{position:absolute;top:26px;right:30px;width:118px;height:118px;opacity:.92;pointer-events:none}
@media(max-width:820px){.hero-deco{display:none}}

/* market tiers */
.signal.locked{opacity:.6}
.sub-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.sub-card{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:12px;padding:16px}
.sub-h{font-family:var(--display);font-weight:600;font-size:15px;color:var(--amber);margin-bottom:12px}
.tier-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.tier{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:10px;padding:12px;text-align:center}
.tier-n{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-dim)}
.tier-p{font-family:var(--display);font-weight:700;font-size:18px;margin:6px 0 10px}
.tier-p span{font-family:var(--mono);font-size:11px;color:var(--txt-faint);font-weight:400}
.tier .mini-btn{width:100%;font-size:11.5px;padding:6px}

/* AI assistant widget */
.ai-fab{position:fixed;bottom:22px;right:22px;z-index:120;background:linear-gradient(140deg,var(--amber),#0a1566);color:#ffffff;border:none;border-radius:999px;padding:13px 20px;font-family:var(--sans);font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 12px 30px -10px rgba(16,32,140,.6)}
.ai-panel{position:fixed;bottom:80px;right:22px;z-index:121;width:340px;max-width:calc(100vw - 36px);background:var(--panel-2);border:1px solid var(--line);border-radius:16px;box-shadow:0 30px 80px -30px rgba(0,0,0,.95);display:none;flex-direction:column;overflow:hidden}
.ai-panel.show{display:flex}
.ai-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);font-family:var(--display);font-weight:600;color:var(--amber)}
.ai-x{background:none;border:none;color:var(--txt-faint);cursor:pointer;font-size:16px}
.ai-tip{padding:13px 16px;font-size:13px;color:var(--txt-dim);background:rgba(67,217,200,.05);border-bottom:1px solid var(--line-soft)}
.ai-chips{display:flex;flex-wrap:wrap;gap:6px;padding:12px 14px}
.ai-chip{background:var(--bg-2);border:1px solid var(--line-soft);border-radius:999px;color:var(--txt-dim);font-size:11.5px;padding:6px 10px;cursor:pointer;font-family:var(--sans)}
.ai-chip:hover{color:var(--teal);border-color:rgba(67,217,200,.35)}
.ai-msgs{max-height:240px;overflow-y:auto;padding:6px 14px;display:flex;flex-direction:column;gap:8px}
.ai-msg{font-size:13px;line-height:1.5;padding:9px 12px;border-radius:11px;max-width:88%}
.ai-msg.you{align-self:flex-end;background:rgba(16,32,140,.12);border:1px solid rgba(16,32,140,.3);color:var(--txt)}
.ai-msg.ai{align-self:flex-start;background:var(--bg-1);border:1px solid var(--line-soft);color:var(--txt-dim)}
.ai-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
.ai-input input{flex:1;background:var(--bg-1);border:1px solid var(--line);border-radius:9px;padding:9px 11px;color:var(--txt);font-family:var(--sans);font-size:13px;outline:none}
.ai-input input:focus{border-color:var(--teal)}
@media(max-width:560px){.sub-grid{grid-template-columns:1fr}.tier-row{grid-template-columns:1fr}}

/* supplier tendering */
.tnl-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin:10px 0}
.tnd{background:var(--bg-1);border:1px solid var(--line-soft);border-radius:11px;padding:13px;margin-bottom:12px}
.tnd-h{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.tnd-id{font-family:var(--mono);font-size:12px;color:var(--txt-faint)}
.tnd-c{font-size:12.5px;color:var(--txt-dim);margin-bottom:9px}
@media(max-width:680px){.tnl-grid{grid-template-columns:1fr 1fr}}

/* customer KYC status banner */
.kyc-banner{border-radius:12px;padding:13px 18px;margin-bottom:18px;font-size:13.5px;color:var(--txt-dim);border:1px solid var(--line)}
.kyc-banner b{color:var(--txt)}
.kyc-banner.pending{background:linear-gradient(100deg,rgba(16,32,140,.1),transparent);border-color:rgba(16,32,140,.35)}
.kyc-banner.pending b{color:var(--amber)}
.kyc-banner.approved{background:linear-gradient(100deg,rgba(52,211,153,.1),transparent);border-color:rgba(52,211,153,.4)}
.kyc-banner.approved b{color:var(--green)}
.kyc-banner.rejected{background:linear-gradient(100deg,rgba(248,113,113,.1),transparent);border-color:rgba(248,113,113,.4)}
.kyc-banner.rejected b{color:var(--red)}

/* support tickets */
.tk-thread{display:flex;flex-direction:column;gap:10px;max-height:380px;overflow-y:auto;padding-right:4px}
.tk-msg{max-width:86%;padding:11px 14px;border-radius:12px}
.tk-msg.client{align-self:flex-end;background:rgba(16,32,140,.1);border:1px solid rgba(16,32,140,.28)}
.tk-msg.support{align-self:flex-start;background:var(--bg-1);border:1px solid var(--line-soft)}
.tk-who{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--txt-faint);margin-bottom:4px}
.tk-msg.client .tk-who{color:var(--amber)}
.tk-msg.support .tk-who{color:var(--teal)}
.tk-body{font-size:13.5px;color:var(--txt);line-height:1.55}
.tk-at{font-family:var(--mono);font-size:10px;color:var(--txt-faint);margin-top:5px;text-align:right}

/* ---- System Health & Self-Test (admin assurance view) ---- */
.sh-banner{display:flex;align-items:center;gap:14px;padding:15px 20px;border-radius:var(--radius);margin-bottom:22px;background:var(--bg-1);border:1px solid var(--line)}
.sh-banner.sh-ok{background:rgba(15,157,111,.08);border-color:rgba(15,157,111,.32)}
.sh-banner.sh-warn{background:rgba(224,138,12,.09);border-color:rgba(224,138,12,.34)}
.sh-banner.sh-fail{background:rgba(229,72,77,.09);border-color:rgba(229,72,77,.36)}
.sh-banner .light{width:13px;height:13px;margin-top:0}
.sh-banner-t{display:flex;flex-direction:column;gap:1px;line-height:1.3}
.sh-banner-t strong{font-family:var(--display);font-size:14.5px;letter-spacing:.05em}
.sh-banner-t span{font-size:12.5px;color:var(--txt-dim)}
.sh-banner .mini-btn{margin-left:auto}
.sh-rows{display:flex;flex-direction:column}
.sh-row{display:grid;grid-template-columns:16px minmax(190px,1.25fr) auto minmax(0,2fr);align-items:start;gap:12px;padding:10px 2px;border-bottom:1px solid var(--line-soft)}
.sh-row:last-child{border-bottom:none}
.sh-row .light{margin-top:4px}
.sh-name{font-size:13.5px;font-weight:600;color:var(--txt)}
.sh-val{font-family:var(--mono);font-size:12px;color:var(--teal);white-space:nowrap;text-align:right;font-weight:600}
.sh-note{font-size:12px;color:var(--txt-faint);line-height:1.45}
@media(max-width:1100px){.sh-row{grid-template-columns:16px 1fr auto}.sh-note{grid-column:2/-1;text-align:left;margin-top:2px}}

/* ---- vessel × port suitability (route planner, #7) ---- */
.vps{border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-top:8px;background:var(--bg-1)}
.vps.ok{border-color:rgba(15,157,111,.34);background:rgba(15,157,111,.06)}
.vps.warn{border-color:rgba(224,138,12,.36);background:rgba(224,138,12,.07)}
.vps.bad{border-color:rgba(229,72,77,.38);background:rgba(229,72,77,.07)}
.vps-rec{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin-bottom:5px}
.vps-ship{font-family:var(--display);font-size:15px;font-weight:600;color:var(--amber)}
.vps-cap{font-family:var(--mono);font-size:11.5px;color:var(--txt-dim)}
.vps-note{font-size:12.5px;color:var(--txt-dim);line-height:1.5;margin-bottom:9px}
.vps-fleet{display:flex;flex-wrap:wrap;gap:6px}
.vps-chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:11px;padding:3px 9px;border-radius:999px;border:1px solid var(--line);background:var(--panel)}
.vps-chip.fit{border-color:rgba(15,157,111,.4);color:var(--green)}
.vps-chip.nofit{border-color:rgba(229,72,77,.35);color:var(--red);opacity:.78}
.vps-chip .vps-d{color:var(--txt-faint);font-size:10px}

/* ---- challenge & dispute resolution (#8) ---- */
.rz-list{display:flex;flex-direction:column;gap:10px}
.rz-row{border:1px solid var(--line);border-left-width:3px;border-radius:9px;padding:11px 14px;background:var(--panel)}
.rz-row.auto{border-left-color:var(--green)}
.rz-row.esc{border-left-color:var(--yellow);background:rgba(224,138,12,.04)}
.rz-top{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:5px}
.rz-type{font-family:var(--display);font-weight:600;font-size:14px;color:var(--txt)}
.rz-ref{font-family:var(--mono);font-size:11px;color:var(--txt-faint)}
.rz-sev{font-family:var(--mono);font-size:10.5px;padding:2px 8px;border-radius:999px;border:1px solid var(--line)}
.rz-sev.r{color:var(--red);border-color:rgba(229,72,77,.35)}
.rz-sev.a{color:var(--yellow);border-color:rgba(224,138,12,.35)}
.rz-sev.g{color:var(--green);border-color:rgba(15,157,111,.35)}
.rz-trig{font-size:12px;color:var(--txt-dim);margin-bottom:7px}
.rz-action{font-size:12.5px;color:var(--txt);line-height:1.5;background:rgba(15,157,111,.06);border-radius:7px;padding:8px 11px}
.rz-action b{color:var(--green)}
.rz-esc{font-size:12.5px;color:var(--txt);line-height:1.5;background:rgba(224,138,12,.07);border-radius:7px;padding:8px 11px}
.rz-esc b{color:var(--yellow)}

/* ---- Deal Optimizer (intelligent execution-path synthesis) ---- */
.opt-score{display:flex;align-items:center;gap:22px;border:1px solid var(--line);border-radius:14px;padding:18px 22px;margin:14px 0 18px;background:var(--bg-1)}
.opt-score.sc-g{border-color:rgba(15,157,111,.36);background:rgba(15,157,111,.06)}
.opt-score.sc-a{border-color:rgba(224,138,12,.36);background:rgba(224,138,12,.06)}
.opt-score.sc-r{border-color:rgba(229,72,77,.38);background:rgba(229,72,77,.06)}
.opt-score-n{font-family:var(--display);font-size:46px;font-weight:700;line-height:1;color:var(--amber);flex-shrink:0}
.opt-score.sc-g .opt-score-n{color:var(--green)}
.opt-score.sc-a .opt-score-n{color:var(--yellow)}
.opt-score.sc-r .opt-score-n{color:var(--red)}
.opt-score-n span{font-size:17px;color:var(--txt-faint);font-weight:400}
.opt-score-b{flex:1;min-width:0}
.opt-score-v{font-size:14.5px;color:var(--txt);margin-bottom:8px}
.opt-flist{display:flex;flex-direction:column;gap:5px}
.opt-f{display:flex;align-items:flex-start;gap:9px;font-size:12.5px}
.opt-f-k{font-weight:600;color:var(--txt);min-width:86px;flex-shrink:0}
.opt-f-v{color:var(--txt-dim);line-height:1.45}
@media(max-width:900px){.opt-score{flex-direction:column;align-items:flex-start;gap:12px}}

/* ---- Deal Optimizer: opportunity-ranking bar ---- */
.opt-bar{height:8px;border-radius:5px;background:var(--bg-2);overflow:hidden;border:1px solid var(--line)}
.opt-bar-v{display:block;height:100%;border-radius:5px;background:var(--teal)}
.opt-bar-v.sc-g{background:var(--green)}
.opt-bar-v.sc-a{background:var(--yellow)}
.opt-bar-v.sc-r{background:var(--red)}

/* ---- challenge resolution: leader action buttons ---- */
.rz-acts{display:flex;gap:8px;margin-top:9px;flex-wrap:wrap}

/* ---- LME / LBMA reference-price board (Market Scan) ---- */
.lme-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:900px){.lme-grid{grid-template-columns:1fr}}
.lme-cat{border:1px solid var(--line);border-radius:var(--radius);padding:12px 13px 7px;background:var(--panel)}
.lme-cat-h{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.lme-glyph{font-size:17px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:9px;background:rgba(14,155,138,.1);color:var(--teal);flex:0 0 auto}
.lme-cat-x{flex:1;min-width:0}
.lme-cat-t{font-weight:700;font-size:13.5px}
.lme-cat-s{font-size:11px;color:var(--txt-faint)}
.lme-src{font-size:11px;color:var(--teal);text-decoration:none;white-space:nowrap;flex:0 0 auto}
.lme-src:hover{text-decoration:underline}
.lme-tbl{margin:0}.lme-tbl td{padding:5px 7px;font-size:12.5px;border-bottom:1px solid var(--line-soft)}
.lme-tbl tr:last-child td{border-bottom:none}
.lme-live{display:inline-flex;align-items:center;gap:5px;font-weight:600;color:var(--teal)}
.lme-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);animation:lmePulse 2s infinite}
@keyframes lmePulse{0%{box-shadow:0 0 0 0 rgba(14,155,138,.45)}70%{box-shadow:0 0 0 6px rgba(14,155,138,0)}100%{box-shadow:0 0 0 0 rgba(14,155,138,0)}}

/* ---- Global price discovery & arbitrage board (user directive — difference price across ALL world markets) ---- */
.garb-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin:0 0 6px}
@media(max-width:760px){.garb-kpis{grid-template-columns:1fr 1fr}}
.garb-kpi{border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;background:var(--panel)}
.garb-kpi-v{font-weight:800;font-size:19px;color:var(--amber);font-family:var(--mono);line-height:1.15}
.garb-kpi-l{font-size:11px;color:var(--txt-faint);margin-top:3px}
.garb-sec-h{font-weight:700;font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-dim);margin:16px 0 9px;padding-bottom:5px;border-bottom:1px solid var(--line)}
.garb-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:920px){.garb-grid{grid-template-columns:1fr}}
.garb-card{border:1px solid var(--line);border-left:3px solid var(--line);border-radius:var(--radius);padding:11px 13px;background:var(--panel)}
.garb-card.open{border-left-color:var(--teal)}
.garb-top{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.garb-id{flex:1;min-width:0;display:flex;align-items:baseline;gap:4px}
.garb-p{font-weight:700;font-size:14px}
.garb-u{font-size:11px;color:var(--txt-faint)}
.garb-fair{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--txt-dim)}
.garb-badge{font-size:9.5px;font-weight:800;letter-spacing:.4px;padding:2px 7px;border-radius:20px;flex:0 0 auto}
.garb-badge.open{background:rgba(14,155,138,.15);color:var(--teal)}
.garb-badge.tight{background:rgba(122,132,153,.14);color:var(--txt-dim)}
.garb-venues{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:9px}
.garb-v{font-size:11px;padding:3px 8px;border-radius:7px;background:var(--bg-1);border:1px solid var(--line-soft);display:inline-flex;align-items:center;gap:5px}
.garb-v b{font-family:var(--mono);font-weight:700}
.garb-v i{font-style:normal;font-size:10px}
.garb-v.buy{border-color:var(--teal);background:rgba(14,155,138,.09)}
.garb-v.sell{border-color:var(--amber);background:rgba(16,32,140,.06)}
.garb-arb{display:flex;flex-direction:column;gap:3px;font-size:11.5px;padding-top:8px;border-top:1px dashed var(--line)}
.garb-route{color:var(--txt-dim)}
.garb-cap{color:var(--txt-faint)}
.garb-profit{color:var(--teal)}
.ms-pp-select{min-width:280px;max-width:440px;flex:1;padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:var(--bg-1);color:var(--txt);font-family:inherit;font-size:13px;cursor:pointer}
.ms-pp-select:hover{border-color:var(--teal)}
/* sellable services — priced proposal + acceptance (point 7) */
/* services depth — indicative estimate, delivery process & milestone tracker */
.svc-est{background:rgba(14,155,138,.06);border:1px solid rgba(14,155,138,.25);border-radius:11px;padding:14px 15px;text-align:center}
.svc-est-v{font-family:var(--mono);font-weight:800;font-size:22px;color:var(--teal);letter-spacing:-.02em;line-height:1.1}
.svc-est-v span{font-size:12px;font-weight:600;color:var(--txt-faint)}
.svc-est-b{font-size:11.5px;color:var(--txt-dim);margin-top:5px;line-height:1.4}
.svc-flow{display:flex;flex-direction:column;gap:7px}
.svc-flow-step{display:flex;align-items:center;gap:10px;font-size:12.5px;color:var(--txt-dim)}
.svc-flow-n{flex:0 0 auto;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-2);color:var(--txt-faint);font-family:var(--mono);font-weight:700;font-size:11px}
.svc-flow-l{font-weight:500}
.svc-track{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.svc-track-step{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--txt-faint);background:var(--bg-1);border:1px solid var(--line-soft);border-radius:20px;padding:4px 11px 4px 5px}
.svc-track-dot{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:var(--line);color:var(--txt-faint);font-size:10px;font-weight:800;font-family:var(--mono)}
.svc-track-step.done{color:var(--teal);border-color:rgba(14,155,138,.3)}
.svc-track-step.done .svc-track-dot{background:var(--teal);color:#fff}
.svc-track-step.current{color:var(--txt);border-color:var(--teal);box-shadow:0 0 0 2px rgba(14,155,138,.12)}
.svc-track-step.current .svc-track-dot{background:var(--amber);color:#fff}
/* selectable service package tiers */
.svc-pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:820px){.svc-pkg-grid{grid-template-columns:1fr}}
.svc-pkg{display:block;cursor:pointer;position:relative}
.svc-pkg input{position:absolute;opacity:0;pointer-events:none}
.svc-pkg-card{border:1.5px solid var(--line);border-radius:13px;padding:15px 16px;background:var(--bg-1);height:100%;transition:border-color .16s,box-shadow .16s,background .16s}
.svc-pkg:hover .svc-pkg-card{border-color:var(--txt-faint)}
.svc-pkg input:checked + .svc-pkg-card{border-color:var(--teal);background:rgba(14,155,138,.05);box-shadow:0 0 0 3px rgba(14,155,138,.12)}
.svc-pkg input:focus-visible + .svc-pkg-card{outline:2px solid var(--teal);outline-offset:2px}
.svc-pkg-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.svc-pkg-n{font-weight:700;font-size:14.5px}
.svc-pkg-rec{font-size:9.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:#fff;background:var(--teal);border-radius:20px;padding:2px 8px;white-space:nowrap}
.svc-pkg-p{font-family:var(--mono);font-weight:800;font-size:21px;color:var(--amber);letter-spacing:-.02em;line-height:1.1}
.svc-pkg-p span{font-size:12px;font-weight:600;color:var(--txt-faint)}
.svc-pkg-basis{font-size:11.5px;color:var(--txt-dim);margin:4px 0 10px}
.svc-pkg-f{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.svc-pkg-f li{font-size:12px;color:var(--txt-dim);padding-left:18px;position:relative;line-height:1.35}
.svc-pkg-f li::before{content:"✓";position:absolute;left:0;color:var(--teal);font-weight:800;font-size:11px}
.svc-pkg-sla{margin-top:11px;font-size:11px;font-weight:600;color:var(--teal);font-family:var(--mono)}
/* ===== service families: two operationally-distinct product lines ===== */
.svc-fam{margin:0 0 28px}
.svc-fam-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:3px}
.svc-fam-l{display:flex;align-items:center;gap:12px}
.svc-fam-no{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:var(--grad-teal,linear-gradient(135deg,#0e9b8a,#0f9d6f));color:#fff;font-family:var(--mono);font-weight:800;font-size:15px;flex:none}
.svc-fam-eyebrow{font-size:10px;font-weight:800;letter-spacing:.7px;color:var(--teal)}
.svc-fam-ttl{margin:1px 0 0;font-size:18px;font-weight:800;letter-spacing:-.01em}
.svc-fam-count{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--txt-dim);white-space:nowrap;background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:4px 11px}
.svc-fam-sub{margin:0 0 13px 42px;font-size:13px;color:var(--txt-dim);max-width:82ch;line-height:1.5}
@media(max-width:640px){.svc-fam-sub{margin-left:0}}
/* executive process band — numbered stages (who/what) + operating meta */
.proc-band{border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,var(--bg-1),var(--bg-0));padding:16px 16px 8px;margin:0 0 16px;box-shadow:var(--shadow-sm,0 1px 2px rgba(16,24,40,.04))}
.proc-flow{display:flex;align-items:stretch;flex-wrap:wrap}
.proc-stage{flex:1 1 150px;min-width:148px;padding:2px 12px 12px 0}
.proc-stage-top{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.proc-stage-n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--mono);font-weight:800;font-size:12px;flex:none}
.proc-stage-who{font-size:9px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--amber);background:rgba(16,32,140,.07);border-radius:20px;padding:2px 7px;white-space:nowrap}
.proc-stage-t{font-weight:700;font-size:12.5px;line-height:1.25;margin-bottom:4px}
.proc-stage-w{font-size:11px;color:var(--txt-dim);line-height:1.4}
.proc-stage-arrow{display:flex;align-items:center;color:#c5ccda;font-size:17px;font-weight:700;padding:0 1px;align-self:center}
@media(max-width:780px){.proc-stage-arrow{display:none}.proc-stage{flex-basis:100%;border-bottom:1px dashed var(--line)}.proc-stage:last-of-type{border-bottom:none}}
.proc-meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border-top:1px solid var(--line);margin-top:4px;padding-top:12px}
@media(max-width:780px){.proc-meta-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.proc-meta-grid{grid-template-columns:1fr}}
.proc-meta-k{display:block;font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--txt-faint);margin-bottom:3px}
.proc-meta-v{font-size:11px;color:var(--txt-dim);line-height:1.4}
/* desk chip groups + kind badge */
.svc-chip-group{margin-bottom:11px}
.svc-chip-group:last-child{margin-bottom:0}
.svc-chip-lbl{font-size:10px;font-weight:800;letter-spacing:.5px;color:var(--txt-faint);text-transform:uppercase;margin-bottom:6px}
.svc-kind-line{display:flex;align-items:center;gap:10px;margin-bottom:13px;flex-wrap:wrap}
.svc-kind-badge{font-size:9.5px;font-weight:800;letter-spacing:.5px;border-radius:6px;padding:3px 9px;color:#fff;flex:none}
.svc-kind-badge.operational{background:var(--teal)}
.svc-kind-badge.advisory{background:var(--amber)}
.svc-kind-tag{font-size:12.5px;color:var(--txt-dim);line-height:1.45}
/* ===== payments & settlement ===== */
.pstats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
@media(max-width:680px){.pstats{grid-template-columns:1fr 1fr}}
.pstat{background:var(--panel,#fff);border:1px solid var(--line);border-radius:13px;padding:14px 16px;box-shadow:var(--shadow-sm,0 1px 2px rgba(16,24,40,.04))}
.pstat-v{font-family:var(--mono);font-weight:800;font-size:22px;letter-spacing:-.02em;line-height:1.1}
.pstat-k{font-size:11px;color:var(--txt-dim);margin-top:3px;font-weight:600}
.pay-cards{display:flex;flex-direction:column;gap:14px}
.pay-card{border:1px solid var(--line);border-radius:14px;padding:16px 18px;background:var(--bg-1);box-shadow:var(--shadow-sm,0 1px 2px rgba(16,24,40,.04))}
.pay-card-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:7px}
.pay-no{font-family:var(--mono);font-weight:800;font-size:13px;letter-spacing:.02em}
.pay-kind{font-size:9.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--txt-dim);background:var(--bg-2);border:1px solid var(--line);border-radius:20px;padding:2px 8px;margin-left:8px}
.pay-card-ttl{font-weight:700;font-size:15px;margin-bottom:2px}
.pay-card-meta{font-size:12px;color:var(--txt-dim);margin-bottom:10px}
.pay-prog{height:7px;border-radius:6px;background:var(--bg-2);overflow:hidden;border:1px solid var(--line)}
.pay-prog-bar{height:100%;background:var(--grad-teal,linear-gradient(90deg,#0e9b8a,#0f9d6f));transition:width .25s}
.pay-prog-l{font-size:11px;color:var(--txt-dim);margin:5px 0 10px;font-family:var(--mono)}
.pay-gate{font-size:12px;font-weight:700;border-radius:9px;padding:8px 12px;margin:0 0 12px}
.pay-gate.ok{background:rgba(15,157,111,.08);color:var(--green);border:1px solid rgba(15,157,111,.25)}
.pay-gate.wait{background:rgba(16,32,140,.05);color:var(--amber);border:1px solid var(--line)}
.pay-insts{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.pay-inst{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--line);border-radius:10px;padding:9px 12px;background:var(--bg-0)}
.pay-inst.received{border-color:rgba(15,157,111,.3);background:rgba(15,157,111,.04)}
.pay-inst-l{display:flex;align-items:center;gap:10px;min-width:0}
.pay-inst-dot{width:9px;height:9px;border-radius:50%;background:var(--line-strong,#c5ccda);flex:none}
.pay-inst-dot.instructed{background:var(--amber)}
.pay-inst-dot.received{background:var(--green)}
.pay-inst-lbl{font-size:12.5px;font-weight:600;line-height:1.2}
.pay-inst-trig{font-size:10.5px;color:var(--txt-faint);margin-top:2px}
.pay-inst-r{display:flex;align-items:center;gap:10px;flex:none}
.pay-inst-amt{font-family:var(--mono);font-weight:700;font-size:13px}
.pay-pending{font-size:11px;color:var(--amber);font-weight:600}
.pay-recv{font-size:11px;color:var(--green);font-weight:700}
.pay-terms-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end;margin-bottom:8px}
@media(max-width:600px){.pay-terms-row{grid-template-columns:1fr}}
.pay-instr{border-top:1px solid var(--line);padding-top:9px;margin-top:2px}
.pay-instr summary{font-size:12px;font-weight:700;color:var(--teal);cursor:pointer;list-style:none}
.pay-instr summary::-webkit-details-marker{display:none}
.pay-instr summary::before{content:"▸ ";color:var(--teal)}
.pay-instr[open] summary::before{content:"▾ "}
.pay-doc-row{margin:0 0 11px;display:flex;gap:8px;flex-wrap:wrap}
.pay-inst.overdue{border-color:rgba(229,72,77,.4);background:rgba(229,72,77,.05)}
.pay-overdue{font-size:9px;font-weight:800;letter-spacing:.4px;color:#fff;background:var(--red);border-radius:4px;padding:1px 5px;margin-left:5px}
.pay-mini-chip{display:inline-block;font-size:10px;font-weight:700;border-radius:5px;padding:1px 6px;margin-left:6px;white-space:nowrap;border:1px solid var(--line)}
.pay-mini-chip.g{color:var(--green);background:rgba(15,157,111,.08);border-color:rgba(15,157,111,.25)}
.pay-mini-chip.a{color:var(--amber);background:rgba(16,32,140,.05)}
.pay-mini-chip.r{color:var(--red);background:rgba(229,72,77,.07);border-color:rgba(229,72,77,.25)}
/* proof-of-payment OCR block */
.pay-inst-wrap{display:flex;flex-direction:column}
.ocr-block{border:1px solid var(--line);border-radius:10px;background:var(--bg-0);padding:10px 12px;margin:6px 0 2px}
.ocr-h{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.ocr-badge{font-size:10px;font-weight:800;letter-spacing:.3px;color:var(--amber);background:rgba(16,32,140,.06);border-radius:5px;padding:2px 7px}
.ocr-file{font-size:10px;color:var(--txt-faint);font-family:var(--mono)}
.ocr-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:5px 16px;margin-bottom:9px}
@media(max-width:560px){.ocr-grid{grid-template-columns:1fr}}
.ocr-f{display:flex;justify-content:space-between;gap:10px;font-size:11px;border-bottom:1px dotted var(--line);padding-bottom:3px}
.ocr-k{color:var(--txt-faint);font-weight:600;white-space:nowrap}
.ocr-v{color:var(--txt-dim);font-family:var(--mono);text-align:right;word-break:break-all}
.ocr-verify{font-size:11.5px;font-weight:700;border-radius:7px;padding:6px 10px}
.ocr-verify.pend{background:rgba(16,32,140,.05);color:var(--amber)}
.ocr-verify.ok{background:rgba(15,157,111,.08);color:var(--green);border:1px solid rgba(15,157,111,.25)}
.ocr-verify.bad{background:rgba(229,72,77,.07);color:var(--red);border:1px solid rgba(229,72,77,.25)}
/* SWIFT message reference */
.swift-cat{margin-bottom:13px}
.swift-cat-h{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--teal);margin-bottom:5px}
.swift-row{display:grid;grid-template-columns:88px 1fr;gap:3px 12px;padding:6px 0;border-bottom:1px solid var(--line)}
.swift-mt{font-family:var(--mono);font-weight:800;color:var(--amber);font-size:12px}
.swift-nm{font-weight:600;font-size:12px}
.swift-iso{font-family:var(--mono);font-weight:600;font-size:10px;color:var(--txt-faint)}
.swift-role{grid-column:2;font-size:11px;color:var(--txt-dim);line-height:1.35}
/* multimodal leg-by-leg routing */
.leg-list{display:flex;flex-direction:column}
.leg-row{display:flex;gap:12px;padding:9px 0;position:relative}
.leg-row:not(:last-child)::after{content:"";position:absolute;left:13px;top:31px;bottom:-1px;width:2px;background:var(--line)}
.leg-row.done:not(:last-child)::after{background:var(--green)}
.leg-seq{flex:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:800;font-size:13px;background:var(--bg-2);color:var(--txt-faint);border:2px solid var(--line);z-index:1}
.leg-row.done .leg-seq{background:var(--green);color:#fff;border-color:var(--green)}
.leg-row.current .leg-seq{background:var(--amber);color:#fff;border-color:var(--amber);box-shadow:0 0 0 3px rgba(16,32,140,.12)}
.leg-body{padding-top:3px;min-width:0}
.leg-route{font-size:13px;line-height:1.4}
.leg-mode{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--teal);background:rgba(14,155,138,.08);border-radius:4px;padding:1px 6px;margin-right:4px}
.leg-meta{font-size:11px;color:var(--txt-dim);margin-top:2px}
/* compliance & screening */
.scr-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.scr-badge{font-size:11px;font-weight:800;letter-spacing:.4px;border-radius:6px;padding:3px 10px;flex:none}
.scr-badge.ok{background:rgba(15,157,111,.1);color:var(--green);border:1px solid rgba(15,157,111,.3)}
.scr-badge.warn{background:rgba(229,72,77,.08);color:var(--red);border:1px solid rgba(229,72,77,.3)}
.scr-cat{margin-bottom:11px}
.scr-cat-h{font-size:10px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--teal);margin-bottom:5px}
.scr-row{display:flex;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:1px solid var(--line)}
.scr-dot{flex:none;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;background:var(--green);color:#fff;margin-top:1px}
.scr-dot.licence{background:var(--amber)}
.scr-body{flex:1;min-width:0}
.scr-item{font-size:12.5px;font-weight:600;line-height:1.3}
.scr-detail{font-size:11px;color:var(--txt-dim);margin-top:1px;line-height:1.35}
.scr-res{flex:none;font-size:9.5px;font-weight:800;letter-spacing:.4px;color:var(--green);align-self:center}
.scr-res.licence{color:var(--amber)}
/* price sparkline */
.usnap-spark{margin:5px 0 3px;height:26px;overflow:hidden}
.spark{display:block;width:100%;height:26px}
.svc-proposal{border:1.5px solid var(--teal);border-radius:14px;padding:16px 18px;background:rgba(14,155,138,.05);margin-bottom:16px}
.svc-proposal-h{display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:var(--display);font-weight:700;font-size:15px;margin-bottom:6px}
.svc-proposal-fee{font-family:var(--mono);font-weight:800;font-size:20px;color:var(--teal);white-space:nowrap}
.svc-proposal-cta{display:flex;gap:9px;flex-wrap:wrap;margin-top:10px}
.adv-quote-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.adv-fee-in,.adv-sow-in{padding:8px 11px;border:1px solid var(--line);border-radius:8px;background:var(--bg-1);color:var(--txt);font-family:inherit;font-size:13px}
.adv-fee-in{width:130px}
.adv-sow-in{flex:1;min-width:180px}
/* help-centre FAQ accordion */
.faq-list{display:flex;flex-direction:column;gap:8px}
.faq-item{border:1px solid var(--line);border-radius:10px;background:var(--bg-1);overflow:hidden}
.faq-q{cursor:pointer;padding:12px 14px;font-weight:600;font-size:13.5px;list-style:none;display:flex;align-items:center;gap:9px}
.faq-q::-webkit-details-marker{display:none}
.faq-q::before{content:"+";font-family:var(--mono);font-weight:700;color:var(--teal);font-size:16px;width:14px;flex:0 0 auto;text-align:center}
.faq-item[open] .faq-q::before{content:"–"}
.faq-item[open] .faq-q{border-bottom:1px solid var(--line)}
.faq-a{padding:11px 14px 13px 37px;font-size:12.5px;color:var(--txt-dim);line-height:1.55}
/* new-client onboarding journey */
.onb-prog{height:7px;background:var(--line-soft);border-radius:20px;overflow:hidden;margin-bottom:6px}
.onb-prog-bar{height:100%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:20px;transition:width .4s}
.onb-prog-cap{font-size:11.5px;color:var(--txt-faint);margin-bottom:14px}
.onb-steps{display:flex;flex-direction:column;gap:8px}
.onb-step{display:flex;align-items:center;gap:12px;padding:11px 13px;border:1px solid var(--line);border-radius:11px;background:var(--bg-1)}
.onb-step.done{border-color:rgba(14,155,138,.3);background:rgba(14,155,138,.04)}
.onb-tick{flex:0 0 auto;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:800;font-size:13px;background:var(--line);color:var(--txt-faint)}
.onb-step.done .onb-tick{background:var(--teal);color:#fff}
.onb-b{flex:1;min-width:0}
.onb-t{font-weight:700;font-size:13.5px}
.onb-d{font-size:11.5px;color:var(--txt-faint);line-height:1.4;margin-top:1px}
.onb-chip{flex:0 0 auto;font-size:10px;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.4px}

/* ---- Deal Optimizer → sourcing task (CTA + desk status pills) ---- */
.opt-cta{margin:0 0 16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.src-status{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:capitalize;letter-spacing:.2px}
.src-queued{background:rgba(16,32,140,.1);color:var(--amber)}
.src-sourcing{background:rgba(214,158,12,.16);color:#a16207}
.src-matched{background:rgba(14,155,138,.15);color:var(--teal)}
.src-closed{background:#eef2f8;color:#7a8499}

/* ---- per-sector demand / supply balance (Market Scan) ---- */
.sb-legend{display:flex;gap:18px;margin:0 0 10px;font-size:11.5px;color:var(--txt-faint)}
.sb-legend span{display:inline-flex;align-items:center;gap:6px}
.sb-key{width:11px;height:11px;border-radius:3px;display:inline-block}
.sb-bar{display:flex;height:9px;border-radius:5px;overflow:hidden;background:#eef2f8;min-width:120px}
.sb-d{background:var(--teal)}.sb-s{background:var(--amber)}
.sb-tone{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700;text-transform:capitalize}
.sb-tight{background:rgba(214,158,12,.16);color:#a16207}
.sb-balanced{background:rgba(14,155,138,.15);color:var(--teal)}
.sb-long{background:rgba(16,32,140,.1);color:var(--amber)}

/* ---- grouped-variant catalog (#3): a product shown ONCE, its variants underneath ---- */
.vcount{background:rgba(16,32,140,.1);color:var(--amber);border-radius:10px;padding:0 6px;font-weight:700;font-size:9.5px;letter-spacing:.3px}
.mch-variants{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.mch-var{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:6px 10px;background:var(--panel);border:1px solid var(--line);border-radius:8px;font-size:12px}
.mch-var-b{font-weight:700}
.mch-var-f{color:var(--teal);font-size:11px}
.mch-var-m{color:var(--txt-faint);font-size:11px;margin-left:auto}
.mch-grouped .pn{display:flex;align-items:center;gap:6px}
.mch-grades{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.mch-grade{font-size:9.5px;font-family:var(--mono);background:rgba(14,155,138,.1);color:var(--teal);border-radius:5px;padding:1px 6px}
.mch-gradecount{font-size:11px;font-weight:600;color:var(--teal);background:rgba(14,155,138,.1);border-radius:10px;padding:1px 8px}

/* ---- Leadership Performance & Evaluation (#1 KPI / OKR) ---- */
.ev-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:980px){.ev-grid{grid-template-columns:1fr}}
.ev-card{border:1px solid var(--line);border-radius:var(--radius);padding:14px;background:var(--panel)}
.ev-platform{border-color:var(--teal);box-shadow:0 0 0 1px rgba(14,155,138,.15)}
.ev-card-top{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.ev-score{width:54px;height:54px;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:0 0 auto;color:#fff}
.ev-score.sc-g{background:var(--green)}.ev-score.sc-a{background:#d69e0c}.ev-score.sc-r{background:var(--red)}
.ev-score-n{font-size:21px;font-weight:800;line-height:1;font-family:var(--mono)}
.ev-score-d{font-size:8px;opacity:.85}
.ev-card-id{flex:1;min-width:0}
.ev-card-ttl{font-weight:700;font-size:13.5px}
.ev-card-dom{font-size:11px;color:var(--txt-faint)}
.ev-rating{text-align:right;flex:0 0 auto}
.ev-rating-b{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700}
.ev-rating-b.g{background:rgba(14,155,138,.15);color:var(--teal)}
.ev-rating-b.a{background:rgba(214,158,12,.16);color:#a16207}
.ev-rating-b.r{background:rgba(248,113,113,.16);color:var(--red)}
.ev-trend{display:block;font-size:10px;margin-top:4px;color:var(--txt-faint)}
.ev-trend.pos{color:var(--green)}.ev-trend.neg{color:var(--red)}
.ev-sec-l{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-faint);margin:12px 0 7px}
.ev-okr-p{float:right;font-weight:800;font-family:var(--mono)}
.ev-okr-p.sc-g{color:var(--green)}.ev-okr-p.sc-a{color:#a16207}.ev-okr-p.sc-r{color:var(--red)}
.ev-kpi{display:flex;align-items:center;gap:8px;margin-bottom:7px}
.ev-kpi-h{flex:1;min-width:0}
.ev-kpi-n{font-size:12px;font-weight:600}
.ev-kpi-v{float:right;font-size:11px;font-family:var(--mono)}
.ev-kpi-t{color:var(--txt-faint)}
.ev-bar{flex:0 0 84px;height:7px;border-radius:4px;background:#eef2f8;overflow:hidden}
.ev-bar-f{display:block;height:100%}
.ev-bar-f.sc-g{background:var(--green)}.ev-bar-f.sc-a{background:#d69e0c}.ev-bar-f.sc-r{background:var(--red)}
.ev-attain{flex:0 0 38px;text-align:right;font-size:11px;font-weight:700;font-family:var(--mono)}
.ev-attain.sc-g{color:var(--green)}.ev-attain.sc-a{color:#a16207}.ev-attain.sc-r{color:var(--red)}
.ev-kr{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}
.ev-kr-t{flex:1;min-width:0}
.ev-kr-bar{flex:0 0 64px;height:6px;border-radius:4px;background:#eef2f8;overflow:hidden}
.ev-kr-f{display:block;height:100%}
.ev-kr-f.sc-g{background:var(--green)}.ev-kr-f.sc-a{background:#d69e0c}.ev-kr-f.sc-r{background:var(--red)}
.ev-kr-p{flex:0 0 34px;text-align:right;font-family:var(--mono);font-size:11px;color:var(--txt-faint)}
.ev-org{display:flex;gap:16px;align-items:stretch;flex-wrap:wrap}
.ev-org-score{width:130px;border-radius:14px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;flex:0 0 auto;padding:14px 0}
.ev-org-score.sc-g{background:var(--green)}.ev-org-score.sc-a{background:#d69e0c}.ev-org-score.sc-r{background:var(--red)}
.ev-org-n{font-size:44px;font-weight:800;line-height:1;font-family:var(--mono)}
.ev-org-l{font-size:12px;font-weight:700;margin-top:5px}
.ev-org-body{flex:1;min-width:240px}
.ev-dist{display:flex;height:16px;border-radius:8px;overflow:hidden;gap:2px}
.ev-dist-seg{display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:700;min-width:18px}
.ev-dist-seg.g{background:var(--green)}.ev-dist-seg.a{background:#d69e0c}.ev-dist-seg.r{background:var(--red)}.ev-dist-seg.r2{background:#991b1b}
.ev-dist-leg{display:flex;gap:14px;margin-top:8px;font-size:11px;color:var(--txt-faint);flex-wrap:wrap}
.ev-dist-leg span{display:inline-flex;align-items:center;gap:5px}
.ev-key{width:10px;height:10px;border-radius:3px;display:inline-block}
.ev-key.g{background:var(--green)}.ev-key.a{background:#d69e0c}.ev-key.r{background:var(--red)}.ev-key.r2{background:#991b1b}
.ev-mini{display:flex;align-items:center;gap:10px;padding:7px 9px;border:1px solid var(--line);border-radius:8px;margin-bottom:6px}
.ev-mini-s{flex:0 0 36px;text-align:center;font-weight:800;font-family:var(--mono);border-radius:6px;padding:3px 0;color:#fff}
.ev-mini-s.sc-g{background:var(--green)}.ev-mini-s.sc-a{background:#d69e0c}.ev-mini-s.sc-r{background:var(--red)}
.ev-mini-t{flex:1;min-width:0;font-size:12.5px;font-weight:600}
.ev-mini-r{font-size:11px;color:var(--txt-faint)}

/* ---- Market Infrastructure (LME market-design model) ---- */
.infra-stack{display:flex;flex-direction:column;align-items:stretch}
.infra-layer{display:flex;gap:12px;border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;background:var(--panel)}
.infra-glyph{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:rgba(16,32,140,.07);color:var(--amber);font-size:19px;flex:0 0 auto}
.infra-l-body{flex:1;min-width:0}
.infra-l-h{display:flex;justify-content:space-between;align-items:baseline;gap:10px;flex-wrap:wrap}
.infra-emo{font-weight:700;font-size:14px}
.infra-stat{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--teal);white-space:nowrap}
.infra-lme{font-size:11px;color:var(--txt-faint);margin:2px 0 5px}
.infra-desc{font-size:12.5px;line-height:1.5}
.infra-sub{font-size:11px;color:var(--txt-faint);margin-top:4px;font-family:var(--mono)}
.infra-arrow{text-align:center;color:var(--txt-faint);font-size:15px;line-height:1.3;padding:1px 0}
.infra-parts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:680px){.infra-parts{grid-template-columns:1fr}}
.infra-part{border:1px solid var(--line);border-radius:9px;padding:8px 10px}
.infra-part.study{opacity:.7;border-style:dashed}
.infra-part-n{font-weight:600;font-size:12.5px}
.infra-part-s{font-size:11px;color:var(--txt-faint);margin-top:3px;display:flex;align-items:center;gap:7px}
.infra-part-b{padding:1px 7px;border-radius:10px;font-size:9.5px;font-weight:700;text-transform:uppercase}
.infra-part-b.g{background:rgba(14,155,138,.15);color:var(--teal)}
.infra-part-b.a{background:rgba(214,158,12,.16);color:#a16207}
.infra-prins{display:flex;flex-direction:column;gap:8px}
.infra-prin{border-left:3px solid var(--teal);padding:4px 0 4px 12px}
.infra-prin-t{font-weight:700;font-size:13px}
.infra-prin-d{font-size:12px;color:var(--txt-faint)}

/* ---- Executive-intelligence strip (Control Tower) ---- */
.exec-intel-l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-faint);margin:2px 0 8px}
.exec-intel-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:16px}
@media(max-width:1100px){.exec-intel-strip{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.exec-intel-strip{grid-template-columns:repeat(2,1fr)}}
.exec-intel{display:flex;align-items:center;gap:9px;text-align:left;border:1px solid var(--line);border-radius:var(--radius);padding:10px 11px;background:var(--panel);cursor:pointer;font:inherit;transition:border-color .15s,transform .1s}
.exec-intel:hover{border-color:var(--teal);transform:translateY(-1px)}
.exec-intel.ei-a{border-left:3px solid #d69e0c}
.exec-intel.ei-r{border-left:3px solid var(--red)}
.exec-intel.ei-g{border-left:3px solid var(--green)}
.ei-gl{font-size:16px;width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:rgba(16,32,140,.07);color:var(--amber);flex:0 0 auto}
.ei-body{flex:1;min-width:0}
.ei-v{font-size:18px;font-weight:800;font-family:var(--mono);line-height:1}
.ei-l{font-size:11.5px;font-weight:600;margin-top:2px}
.ei-sub{font-size:10px;color:var(--txt-faint)}
.ei-arrow{color:var(--txt-faint);font-size:14px;flex:0 0 auto}

/* ---- Executive briefing (auto-generated narrative) ---- */
.brief-headline{font-size:15px;font-weight:700;line-height:1.5;padding:11px 14px;background:rgba(14,155,138,.07);border-radius:10px;border-left:3px solid var(--teal);margin-bottom:14px}
.brief-secs{display:flex;flex-direction:column;gap:11px;margin-bottom:14px}
.brief-sec{display:flex;gap:10px;align-items:flex-start}
.brief-sec .light{margin-top:5px;flex:0 0 auto}
.brief-sec-k{font-weight:700;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--txt-faint)}
.brief-sec-t{font-size:13px;line-height:1.55}
.brief-act-l{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--txt-faint);margin:0 0 6px}
.brief-acts{margin:0;padding-left:20px}
.brief-acts li{font-size:13px;line-height:1.6;margin-bottom:4px}

/* ---- Customer live market windows (opportunities) ---- */
.opp-wins{display:flex;flex-direction:column;gap:8px}
.opp-win{border:1px solid var(--line);border-left:3px solid var(--teal);border-radius:8px;padding:9px 11px}
.opp-win-h{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.opp-win-b{font-weight:700;font-size:13px}
.opp-win-pct{font-family:var(--mono);font-weight:700;color:var(--teal);font-size:13px}
.opp-win-s{font-size:11.5px;color:var(--txt-faint);margin-top:2px}

/* ---- Customer About page (modern, rich) ---- */
.about-tagline{font-size:22px;font-weight:800;color:var(--teal);text-align:center;margin:2px 0 20px;letter-spacing:-.3px}
.about-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}
@media(max-width:900px){.about-stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.about-stats{grid-template-columns:repeat(2,1fr)}}
.about-stat{text-align:center;padding:16px 10px;border:1px solid var(--line);border-radius:var(--radius);background:linear-gradient(180deg,rgba(14,155,138,.05),transparent)}
.about-stat-v{font-size:26px;font-weight:800;font-family:var(--mono);color:var(--amber);line-height:1}
.about-stat-l{font-size:11px;color:var(--txt-faint);margin-top:5px}
.about-lead{font-size:14px;line-height:1.6;margin:0}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
.value-card{padding:16px;border:1px solid var(--line);border-radius:var(--radius);text-align:center;background:var(--panel)}
.value-ic{width:44px;height:44px;margin:0 auto 10px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:rgba(14,155,138,.1);color:var(--teal);font-size:20px}
.value-t{font-weight:700;font-size:14px;margin-bottom:5px}
.value-d{font-size:12px;color:var(--txt-faint);line-height:1.5}
.diff-grid{display:flex;flex-direction:column;gap:11px}
.diff-item{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;line-height:1.55}
.diff-dot{width:9px;height:9px;border-radius:50%;background:var(--teal);margin-top:5px;flex:0 0 auto;display:inline-block}
.about-cta{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:16px;padding:20px 22px;border-radius:var(--radius);background:linear-gradient(120deg,rgba(16,32,140,.06),rgba(14,155,138,.06));border:1px solid var(--line)}
.about-cta-t{font-size:17px;font-weight:800}
.about-cta-d{font-size:13px;color:var(--txt-faint);margin-top:3px}
.about-cta-btns{display:flex;gap:8px;flex-wrap:wrap}

/* ============================================================
   PREMIUM VISUAL MODERNIZATION — elevation, refined CTAs,
   typography & micro-interaction polish. Appended so it overrides
   earlier same-specificity rules. Layout-safe: colour / shadow /
   transform only, no structural or sizing changes.
   ============================================================ */
:root{
  --shadow-sm:0 1px 2px rgba(16,24,40,.05),0 1px 3px rgba(16,24,40,.05);
  --shadow-md:0 6px 16px -6px rgba(16,24,40,.10),0 14px 32px -18px rgba(16,24,40,.18);
  --shadow-lg:0 22px 50px -26px rgba(16,24,40,.30);
  --shadow-pop:0 30px 70px -30px rgba(16,32,140,.34);
  --grad-teal:linear-gradient(135deg,#14b3a2,#0b8273);
  --grad-navy:linear-gradient(135deg,#1a30ad,#0a1566);
}
/* subtle page depth (super-light brand wash) */
body{background:radial-gradient(1100px 560px at 82% -12%,rgba(16,32,140,.05),transparent 60%),radial-gradient(820px 460px at -8% 8%,rgba(14,155,138,.045),transparent 55%),var(--bg-0);background-attachment:fixed}
/* panels — hairline border + layered elevation + gentle hover */
.panel{border:1px solid var(--line-soft);box-shadow:var(--shadow-md);transition:box-shadow .26s ease,transform .26s ease}
.panel:hover{box-shadow:var(--shadow-lg)}
/* tighter, more confident headings */
.panel-head h3,.hero-h,h1,h2,h3,.head-h1{letter-spacing:-.018em}
/* premium primary CTA — filled, white text, soft shadow, lift */
.mini-btn{transition:transform .14s ease,box-shadow .18s ease,border-color .18s,color .18s,background .2s}
.mini-btn.solid{background:var(--grad-teal);border-color:transparent;color:#fff;box-shadow:0 1px 2px rgba(11,130,115,.28),0 9px 20px -10px rgba(11,130,115,.55)}
.mini-btn.solid:hover{color:#fff;transform:translateY(-1.5px);box-shadow:0 2px 5px rgba(11,130,115,.32),0 16px 30px -12px rgba(11,130,115,.62)}
.mini-btn.solid:active{transform:translateY(0)}
.mini-btn:not(.solid):not(.ghost):hover{transform:translateY(-1px)}
/* stat tiles — always-on gradient accent edge, refined figure, lift */
.stat{box-shadow:var(--shadow-sm)}
.stat::before{opacity:.6;background:linear-gradient(180deg,var(--amber),var(--teal))}
.stat:hover{box-shadow:var(--shadow-md)}
.stat .v{background:linear-gradient(135deg,var(--amber),#3146bd);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}
/* hero — soft surface + elevation */
.hero{box-shadow:var(--shadow-md);background:linear-gradient(165deg,#ffffff,#f6f8fe)}
/* interactive cards come alive on hover */
.opp-card,.svc-card,.uc-lane,.corr-card{transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.opp-card:hover,.svc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
/* richer table row hover */
.data-table tr:hover td,.md-table tr:hover td{background:rgba(16,32,140,.028)}
/* modal & sheet elevation */
.umodal-card,.mch-modal-card,.news-modal-card,.modal-card,.umodal .panel{box-shadow:var(--shadow-pop)}
