  :root{
    --abyss:#06121A;
    --ink:#0A1B25;
    --panel:#0C212D;
    --surface:#0F2A38;
    --line:rgba(120,180,200,.14);
    --line-strong:rgba(120,180,200,.26);
    --mist:#8FAEBC;
    --mist-dim:#5E7C8A;
    --foam:#EAF4F7;
    --sonar:#46E5C8;
    --sonar-deep:#1FB89E;

    --bu-de:#46E5C8;
    --bu-pmcm:#5B9BFF;
    --bu-her:#E8B45C;
    --bu-corp:#B08CFF;

    --display:'Bricolage Grotesque',serif;
    --body:'Hanken Grotesk',system-ui,sans-serif;
    --mono:'JetBrains Mono',ui-monospace,monospace;

    --r:14px;
    --r-sm:10px;
    --ease:cubic-bezier(.2,.7,.2,1);
  }

  *{box-sizing:border-box;margin:0;padding:0}
  html,body{height:100%}
  body{
    background:
      radial-gradient(150% 130% at 10% -28%, rgba(70,229,200,.07), rgba(70,229,200,0) 62%),
      radial-gradient(140% 130% at 110% 128%, rgba(91,155,255,.06), rgba(91,155,255,0) 62%),
      var(--abyss);
    color:var(--foam);
    font-family:var(--body);
    font-size:15px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  ::selection{background:rgba(70,229,200,.28);color:var(--foam)}
  a{color:inherit}
  button{font-family:inherit;cursor:pointer;color:inherit}
  :focus-visible{outline:2px solid var(--sonar);outline-offset:3px;border-radius:6px}

  .mono{font-family:var(--mono);font-feature-settings:"tnum" 1;letter-spacing:-.01em}
  .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--mist-dim)}

  .shell{max-width:1480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}

  /* top bar */
  .topbar{
    display:flex;align-items:center;gap:24px;
    padding:18px 30px;border-bottom:1px solid var(--line);
    position:sticky;top:0;z-index:40;
    background:linear-gradient(180deg, rgba(6,18,26,.92), rgba(6,18,26,.62));
    backdrop-filter:blur(14px);
  }
  .brand{display:flex;align-items:center;gap:13px;flex-shrink:0}
  .mark{width:34px;height:34px;flex-shrink:0}
  .mark svg{display:block;width:100%;height:100%}
  .ring{transform-origin:center;animation:spin 16s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  .wordmark{display:flex;flex-direction:column;line-height:1}
  .wordmark b{font-family:var(--display);font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--foam)}
  .wordmark span{font-family:var(--mono);font-size:9px;letter-spacing:.18em;color:var(--mist-dim);text-transform:uppercase;margin-top:3px}

  .firm{margin-left:6px;padding-left:18px;border-left:1px solid var(--line);display:flex;flex-direction:column;line-height:1.1}
  .firm small{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--mist-dim)}
  .firm strong{font-size:13.5px;font-weight:600;color:var(--mist);margin-top:3px}

  .topright{margin-left:auto;display:flex;align-items:center;gap:14px}
  .live{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--mist)}
  .pulse{width:7px;height:7px;border-radius:50%;background:var(--sonar);animation:pulse 2.4s var(--ease) infinite}
  @keyframes pulse{0%{box-shadow:0 0 0 0 rgba(70,229,200,.5)}70%{box-shadow:0 0 0 9px rgba(70,229,200,0)}100%{box-shadow:0 0 0 0 rgba(70,229,200,0)}}
  .ava{width:34px;height:34px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#15323f,#0c2330);
    border:1px solid var(--line-strong);display:grid;place-items:center;font-family:var(--mono);font-size:12px;color:var(--sonar);
    cursor:pointer;transition:border-color .2s,transform .15s}
  .ava:hover{border-color:var(--sonar);transform:translateY(-1px)}

  .main{display:grid;grid-template-columns:1fr 392px;flex:1;min-height:0}
  .stage{padding:28px 30px;display:flex;flex-direction:column;gap:24px;min-width:0}
  .aside{border-left:1px solid var(--line);display:flex;flex-direction:column;min-height:0;
    background:linear-gradient(180deg, rgba(12,33,45,.5), rgba(8,24,33,.2))}

  /* pool card */
  .pool-card{
    position:relative;border:1px solid var(--line);border-radius:var(--r);
    background:radial-gradient(130% 100% at 50% 0%, #0a2230, #06141d 72%);
    overflow:hidden;min-height:512px;
    box-shadow:inset 0 1px 0 rgba(255,255,255,.03), 0 30px 60px -30px rgba(0,0,0,.7);
  }
  #pool{display:block;width:100%;height:100%;position:absolute;inset:0;z-index:1}
  .pool-head{position:absolute;top:0;left:0;right:0;z-index:5;padding:22px 24px;pointer-events:none}
  .pool-head .eyebrow{margin-bottom:9px}
  .pool-head h1{font-family:var(--display);font-weight:700;font-size:clamp(23px,2.6vw,32px);
    letter-spacing:-.025em;line-height:1.04;max-width:18ch}
  .pool-head h1 i{font-style:normal;color:var(--sonar)}
  .pool-head p{margin-top:8px;color:var(--mist);max-width:44ch;font-size:13.5px}
  .hero-copy{overflow:hidden;max-height:220px;opacity:1;
    transition:max-height .55s var(--ease), opacity .32s var(--ease), transform .55s var(--ease)}
  .pool-head.compact .hero-copy{max-height:0;opacity:0;transform:translateY(-12px)}
  .pool-head.compact .lens{margin-top:0}

  /* lens */
  .lens{margin-top:16px;display:inline-flex;gap:3px;padding:4px;pointer-events:auto;
    background:rgba(6,16,23,.72);border:1px solid var(--line-strong);border-radius:12px;
    backdrop-filter:blur(8px);max-width:100%;overflow-x:auto;scrollbar-width:none}
  .lens::-webkit-scrollbar{display:none}
  .lens .lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--mist-dim);align-self:center;padding:0 9px 0 6px;white-space:nowrap}
  .lensbtn{font-size:12.5px;color:var(--mist);background:transparent;border:none;padding:7px 13px;border-radius:8px;
    white-space:nowrap;transition:color .2s, background .2s;font-weight:500}
  .lensbtn:hover{color:var(--foam)}
  .lensbtn[aria-pressed="true"]{color:#06141d;background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));
    box-shadow:0 4px 14px -4px rgba(70,229,200,.6);font-weight:600}

  /* cluster labels */
  .pool-labels{position:absolute;inset:0;z-index:4;pointer-events:none}
  .clabel{position:absolute;transform:translate(-50%,0);pointer-events:auto;cursor:pointer;overflow:hidden;
    text-align:center;transition:opacity .4s var(--ease);opacity:0;white-space:nowrap}
  .clabel .cn{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--foam);
    max-width:100%;overflow:hidden;text-overflow:ellipsis;display:block;text-shadow:0 1px 6px rgba(0,0,0,.8)}
  .clabel .cc{font-family:var(--mono);font-size:9px;color:var(--mist-dim);margin-top:1px}
  .clabel:hover .cn{color:var(--sonar)}
  .clabel .dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:5px;vertical-align:middle}

  .tooltip{position:absolute;z-index:6;pointer-events:none;opacity:0;transform:translateY(4px);
    transition:opacity .15s, transform .15s;background:rgba(8,24,33,.96);border:1px solid var(--line-strong);
    border-radius:10px;padding:9px 12px;min-width:160px;backdrop-filter:blur(8px);
    box-shadow:0 16px 30px -12px rgba(0,0,0,.8)}
  .tooltip.on{opacity:1;transform:translateY(0)}
  .tooltip .tt-role{font-size:13px;font-weight:600}
  .tooltip .tt-meta{font-family:var(--mono);font-size:10px;color:var(--mist);margin-top:4px;display:flex;flex-wrap:wrap;gap:7px}
  .tooltip .tt-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle}

  .gauge{position:absolute;bottom:0;left:0;right:0;z-index:5;display:flex;gap:22px;align-items:center;
    flex-wrap:wrap;padding:16px 24px;background:linear-gradient(0deg, rgba(6,18,26,.9), transparent);pointer-events:none}
  .gauge .reading{display:flex;flex-direction:column;gap:3px}
  .gauge .num{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:-.02em;line-height:1}
  .gauge .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--mist-dim)}
  .gauge .sep{width:1px;height:30px;background:var(--line)}

  /* panels */
  .panels{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
  .panel{border:1px solid var(--line);border-radius:var(--r);padding:22px 22px 24px;
    background:linear-gradient(180deg, rgba(12,33,45,.55), rgba(9,26,36,.35))}
  .panel-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px;gap:12px}
  .panel-head h2{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:-.01em}
  .panel-head .meta{font-family:var(--mono);font-size:10px;color:var(--mist-dim)}

  .bars{display:flex;flex-direction:column;gap:11px}
  .bar{display:grid;grid-template-columns:1fr 130px 44px;align-items:center;gap:12px;cursor:pointer}
  .bar .name{font-size:13px;color:var(--mist);transition:color .2s;display:flex;align-items:center;gap:8px;
    overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .bar:hover .name{color:var(--foam)}
  .bar .swatch{width:9px;height:9px;border-radius:3px;flex-shrink:0}
  .bar .track{height:8px;border-radius:6px;background:rgba(120,180,200,.08);overflow:hidden;position:relative}
  .bar .fill{position:absolute;inset:0;width:0;border-radius:6px;transition:width .9s var(--ease)}
  .bar .fill::after{content:"";position:absolute;top:0;right:0;bottom:0;width:3px;border-radius:6px;
    background:rgba(255,255,255,.55);filter:blur(1px);opacity:.7}
  .bar .val{font-family:var(--mono);font-size:12px;color:var(--mist);text-align:right}

  /* schema */
  .levels{list-style:none;display:flex;flex-direction:column;gap:1px;margin-bottom:18px}
  .levels li{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid rgba(120,180,200,.07)}
  .levels li:last-child{border-bottom:none}
  .levels .lvl{font-family:var(--mono);font-size:10px;color:var(--sonar);width:22px;flex-shrink:0}
  .levels .lname{font-size:13.5px;color:var(--foam);font-weight:500}
  .levels .ldesc{font-size:11.5px;color:var(--mist-dim);margin-left:auto;text-align:right}
  .levels .lct{font-family:var(--mono);font-size:12px;color:var(--mist);width:42px;text-align:right;flex-shrink:0}

  .record{border:1px solid var(--line);border-radius:var(--r-sm);padding:14px;
    background:linear-gradient(180deg, rgba(70,229,200,.05), transparent)}
  .rec-eyebrow{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mist-dim);margin-bottom:10px}
  .trail{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:11px}
  .trail span{font-size:11.5px;color:var(--mist);background:rgba(120,180,200,.08);padding:3px 8px;border-radius:6px;
    opacity:0;transform:translateY(5px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
  .trail span.in{opacity:1;transform:none}
  .trail b{color:var(--mist-dim);font-weight:400}
  .rec-title{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em;margin-bottom:11px}
  .rec-tags{display:flex;flex-wrap:wrap;gap:6px}
  .tg{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:6px;border:1px solid var(--line);color:var(--mist)}
  .tg.sec{color:var(--bu-her);border-color:rgba(232,180,92,.3)}
  .tg.exp{color:var(--sonar);border-color:rgba(70,229,200,.3)}
  .tg.pt{color:var(--bu-pmcm);border-color:rgba(91,155,255,.3)}
  .tg.loc{color:var(--bu-corp);border-color:rgba(176,140,255,.3)}

  /* chat */
  .chat-head{padding:22px 22px 16px;border-bottom:1px solid var(--line)}
  .chat-head .row{display:flex;align-items:center;gap:11px}
  .chat-head .orb{width:30px;height:30px;border-radius:9px;
    background:radial-gradient(circle at 35% 30%, #6effe0, #1fb89e 70%, #0d6d5e);box-shadow:0 0 18px -2px rgba(70,229,200,.6)}
  .chat-head h2{font-family:var(--display);font-weight:700;font-size:16px;letter-spacing:-.01em}
  .chat-head .sub{font-family:var(--mono);font-size:9.5px;color:var(--mist-dim);letter-spacing:.12em;text-transform:uppercase}

  .thread{flex:1;overflow-y:auto;padding:20px 20px 8px;display:flex;flex-direction:column;gap:16px;scroll-behavior:smooth}
  .thread::-webkit-scrollbar{width:8px}
  .thread::-webkit-scrollbar-thumb{background:rgba(120,180,200,.18);border-radius:8px}

  .msg{max-width:92%;font-size:14px;line-height:1.5;animation:rise .45s var(--ease) both}
  @keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
  .msg.user{align-self:flex-end;background:linear-gradient(135deg,#13384a,#0e2c3b);
    border:1px solid var(--line-strong);padding:10px 14px;border-radius:14px 14px 4px 14px;color:var(--foam)}
  .msg.bot{align-self:flex-start;color:var(--mist)}
  .msg.bot .who{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;
    color:var(--sonar-deep);margin-bottom:6px;display:flex;align-items:center;gap:7px}
  .msg.bot .who::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--sonar)}
  .msg.bot strong{color:var(--foam);font-weight:600}

  .typing{display:flex;gap:5px;padding:4px 0}
  .typing span{width:7px;height:7px;border-radius:50%;background:var(--sonar);opacity:.5;animation:blink 1.2s infinite}
  .typing span:nth-child(2){animation-delay:.18s}.typing span:nth-child(3){animation-delay:.36s}
  @keyframes blink{0%,60%,100%{opacity:.25;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}

  .cards{display:flex;flex-direction:column;gap:10px;margin-top:4px}
  .cand{border:1px solid var(--line);border-radius:12px;padding:12px 13px;
    background:linear-gradient(180deg, rgba(15,42,56,.6), rgba(10,27,37,.4));
    transition:transform .25s var(--ease), border-color .25s, box-shadow .25s;animation:rise .5s var(--ease) both}
  .cand:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 18px 30px -18px rgba(0,0,0,.8)}
  .cand .top{display:flex;align-items:center;gap:11px}
  .cand .ci{width:36px;height:36px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;
    font-family:var(--mono);font-size:12px;font-weight:600;color:#06141d}
  .cand .nm{font-size:14px;font-weight:600;line-height:1.15}
  .cand .rl{font-size:11.5px;color:var(--mist);margin-top:2px;display:flex;align-items:center;gap:6px}
  .cand .bud{width:7px;height:7px;border-radius:2px;flex-shrink:0}
  .cand .score{margin-left:auto;text-align:right}
  .cand .score b{font-family:var(--mono);font-size:14px;color:var(--sonar)}
  .cand .score small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:.1em;color:var(--mist-dim);text-transform:uppercase}
  .cand .foot{display:flex;align-items:center;gap:6px;margin-top:11px;flex-wrap:wrap}
  .cand .chip{font-family:var(--mono);font-size:10px;color:var(--mist);background:rgba(120,180,200,.08);
    border:1px solid var(--line);padding:3px 7px;border-radius:6px}
  .cand .loc{font-family:var(--mono);font-size:10.5px;color:var(--mist-dim);margin-left:auto;display:flex;align-items:center;gap:5px}

  .composer{padding:14px 18px 18px;border-top:1px solid var(--line);background:rgba(8,24,33,.5)}
  .suggest{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
  .chipbtn{font-size:12px;color:var(--mist);background:transparent;border:1px solid var(--line-strong);
    padding:7px 11px;border-radius:20px;transition:.2s;white-space:nowrap}
  .chipbtn:hover{color:var(--foam);border-color:var(--sonar);background:rgba(70,229,200,.06)}
  .inputrow{display:flex;align-items:center;gap:9px;min-height:52px;border:1px solid var(--line-strong);
    border-radius:14px;padding:7px 8px 7px 15px;background:rgba(6,18,26,.7);transition:border-color .2s}
  .inputrow:focus-within{border-color:var(--sonar)}
  .inputrow textarea{flex:1;display:block;background:transparent;border:none;color:var(--foam);font-family:var(--body);
    font-size:14px;line-height:1.45;height:22px;max-height:96px;outline:none;padding:0;margin:0;
    resize:none;overflow-y:auto;appearance:none;-webkit-appearance:none}
  .inputrow textarea::-webkit-resizer{display:none}
  .inputrow textarea::placeholder{color:var(--mist-dim)}
  .send{width:38px;height:38px;border-radius:10px;border:none;flex-shrink:0;
    background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));display:grid;place-items:center;
    transition:transform .15s, box-shadow .2s;box-shadow:0 6px 18px -6px rgba(70,229,200,.7)}
  .send:hover{transform:translateY(-1px)}.send:active{transform:translateY(0)}
  .send svg{width:17px;height:17px}

  .veil{position:fixed;inset:0;z-index:80;background:var(--abyss);display:grid;place-items:center;
    transition:opacity .8s var(--ease), visibility .8s}
  .veil.gone{opacity:0;visibility:hidden}
  .veil .vmark{width:64px;height:64px;animation:dive 1.6s var(--ease) infinite}
  @keyframes dive{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
  .veil .vtxt{position:absolute;bottom:34%;font-family:var(--mono);font-size:11px;letter-spacing:.28em;
    text-transform:uppercase;color:var(--mist-dim)}

  footer{padding:20px 30px;border-top:1px solid var(--line);display:flex;justify-content:space-between;
    align-items:center;gap:16px;flex-wrap:wrap;color:var(--mist-dim);font-size:12.5px}
  footer .mono{color:var(--mist)}
  footer b{color:var(--mist);font-weight:600}

  @media (max-width:1080px){
    .main{grid-template-columns:1fr}
    .aside{border-left:none;border-top:1px solid var(--line);height:640px}
    .panels{grid-template-columns:1fr}
  }
  @media (max-width:620px){
    .firm{display:none}
    .stage{padding:18px}
    .topbar{padding:14px 18px;gap:14px}
    .pool-card{min-height:460px}
    .gauge .sep:nth-of-type(n+2){display:none}
    footer{padding:18px}
  }
  /* ===== tabs ===== */
  .tabs{display:flex;gap:4px;margin:0 auto;background:rgba(6,16,23,.6);border:1px solid var(--line);
    border-radius:12px;padding:4px}
  .tab{display:flex;align-items:center;gap:8px;padding:8px 15px;border:none;background:transparent;
    color:var(--mist);font-size:13.5px;font-weight:500;border-radius:8px;transition:.2s;white-space:nowrap}
  .tab svg{width:16px;height:16px;opacity:.8}
  .tab:hover{color:var(--foam);background:rgba(120,180,200,.06)}
  .tab[aria-current="true"]{color:#06141d;background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));
    box-shadow:0 4px 14px -4px rgba(70,229,200,.55)}
  .tab[aria-current="true"] svg{opacity:1}

  .view[hidden]{display:none!important}
  .view{animation:viewIn .5s var(--ease)}
  @keyframes viewIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

  .sec-head{margin-bottom:24px;max-width:680px}
  .sec-head h2{font-family:var(--display);font-weight:700;font-size:clamp(24px,2.6vw,32px);letter-spacing:-.025em;line-height:1.05;margin-top:8px}
  .sec-head h2 i{font-style:normal;color:var(--sonar)}
  .sec-head p{margin-top:10px;color:var(--mist);font-size:14.5px}

  /* ===== ingest ===== */
  .ingest{padding:30px}
  .ing-wrap{max-width:1180px;margin:0 auto;display:flex;flex-direction:column;gap:22px}
  .ing-top{display:grid;grid-template-columns:1.15fr .85fr;gap:22px}
  .dropzone{position:relative;border:1.5px dashed var(--line-strong);border-radius:var(--r);
    padding:38px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
    text-align:center;cursor:pointer;overflow:hidden;transition:border-color .25s, background .25s;min-height:220px;
    background:radial-gradient(120% 100% at 50% 0%, rgba(70,229,200,.05), transparent 70%)}
  .dropzone:hover,.dropzone.drag{border-color:var(--sonar);background:radial-gradient(120% 100% at 50% 0%, rgba(70,229,200,.1), transparent 70%)}
  .dropzone svg{width:38px;height:38px;color:var(--sonar)}
  .dz-title{font-family:var(--display);font-weight:700;font-size:18px}
  .dz-sub{font-size:13px;color:var(--mist)}
  .dz-sub .lk{color:var(--sonar);text-decoration:underline;text-underline-offset:3px}
  .dz-glow{position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 120%, rgba(70,229,200,.18), transparent 70%);
    opacity:0;transition:opacity .3s;pointer-events:none}
  .dropzone.drag .dz-glow{opacity:1}

  .urlbox{border:1px solid var(--line);border-radius:var(--r);padding:22px;
    background:linear-gradient(180deg, rgba(12,33,45,.55), rgba(9,26,36,.35));display:flex;flex-direction:column;gap:12px}
  .ub-h{font-family:var(--display);font-weight:700;font-size:16px}
  .ub-row{display:flex;gap:9px}
  .ub-row input{flex:1;background:rgba(6,18,26,.7);border:1px solid var(--line-strong);border-radius:10px;
    padding:11px 13px;color:var(--foam);font-family:var(--body);font-size:13.5px;outline:none;transition:border-color .2s}
  .ub-row input:focus{border-color:var(--sonar)}
  .ub-btn{background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));color:#06141d;border:none;
    border-radius:10px;padding:0 18px;font-weight:600;font-size:13.5px}
  .ub-note{font-size:12.5px;color:var(--mist-dim);line-height:1.5}
  .ub-quick{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:2px}
  .ub-quick span{font-size:12px;color:var(--mist-dim)}
  .qchip{font-size:12px;color:var(--mist);background:transparent;border:1px solid var(--line-strong);
    border-radius:20px;padding:6px 11px;transition:.2s}
  .qchip:hover{color:var(--foam);border-color:var(--sonar);background:rgba(70,229,200,.06)}

  .pipe-panel .panel-head .meta{text-transform:uppercase;letter-spacing:.1em}
  .pipeline{display:flex;align-items:stretch;gap:0;overflow-x:auto;padding:6px 2px 2px;scrollbar-width:none}
  .pipeline::-webkit-scrollbar{display:none}
  .pstage{flex:1;min-width:96px;display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;
    padding:14px 6px;border-radius:12px;transition:background .3s;position:relative}
  .pstage .sdot{width:34px;height:34px;border-radius:11px;border:1px solid var(--line-strong);
    display:grid;place-items:center;background:rgba(8,24,33,.6);transition:.35s;position:relative}
  .pstage .sdot::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--mist-dim);transition:.35s}
  .pstage .sname{font-size:13px;font-weight:600;color:var(--mist);transition:color .3s}
  .pstage .sdesc{font-family:var(--mono);font-size:9.5px;color:var(--mist-dim);letter-spacing:.04em}
  .pstage.active .sdot{border-color:var(--sonar);box-shadow:0 0 18px -2px rgba(70,229,200,.6)}
  .pstage.active .sdot::after{background:var(--sonar);box-shadow:0 0 10px var(--sonar)}
  .pstage.active .sname{color:var(--foam)}
  .pstage.done .sdot{border-color:var(--sonar-deep)}
  .pstage.done .sdot::after{background:var(--sonar-deep)}
  .sconn{flex:0 0 26px;align-self:flex-start;margin-top:30px;height:2px;background:var(--line);position:relative;
    border-radius:2px;overflow:hidden}
  .sconn i{position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--sonar),var(--sonar-deep));transition:width .4s var(--ease)}
  .sconn.lit i{width:100%}
  .pipe-result{margin-top:14px}
  .pipe-result .res{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:12px;
    padding:12px 14px;background:linear-gradient(180deg, rgba(70,229,200,.06), transparent);animation:rise .5s var(--ease) both}
  .pipe-result .res .ci{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
    font-family:var(--mono);font-weight:600;font-size:12px;color:#06141d;flex-shrink:0}
  .pipe-result .res .rt{font-size:14px;font-weight:600}
  .pipe-result .res .rtrail{font-family:var(--mono);font-size:10.5px;color:var(--mist);margin-top:3px}
  .pipe-result .res .tags{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;max-width:50%}
  .pipe-result .res .tg2{font-family:var(--mono);font-size:10px;color:var(--mist);border:1px solid var(--line);border-radius:6px;padding:3px 7px}

  .ing-bottom{display:grid;grid-template-columns:1fr 1fr;gap:22px}
  .queue{display:flex;flex-direction:column;gap:10px}
  .qitem{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:11px;padding:10px 12px;
    background:linear-gradient(180deg, rgba(15,42,56,.5), rgba(10,27,37,.3))}
  .qitem .ci{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-family:var(--mono);
    font-size:11px;font-weight:600;color:#06141d;flex-shrink:0}
  .qitem .qn{font-size:13.5px;font-weight:600}
  .qitem .qm{font-size:11px;color:var(--mist);margin-top:1px}
  .qitem .qc{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--sonar);text-align:right}
  .qitem .qc small{display:block;color:var(--mist-dim);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase}

  .train{display:flex;flex-direction:column;gap:16px}
  .train-stats{display:flex;gap:10px}
  .train-stats .ts{flex:1;border:1px solid var(--line);border-radius:10px;padding:11px;text-align:center;
    background:rgba(8,24,33,.4)}
  .train-stats .tsv{font-size:18px;font-weight:700;font-family:var(--display);letter-spacing:-.01em}
  .train-stats .tsl{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--mist-dim);margin-top:3px}
  .losswrap{border:1px solid var(--line);border-radius:10px;padding:12px;background:rgba(8,24,33,.4)}
  .loss-head{display:flex;justify-content:space-between;font-size:11.5px;color:var(--mist);margin-bottom:8px}
  .loss-head .mono{color:var(--mist-dim);font-size:10px}
  .loss{width:100%;height:90px;display:block}
  .train-ctl{display:flex;flex-direction:column;gap:13px}
  .ctl-row{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--mist)}
  .ctl-row label{flex:1}
  .rng{flex:0 0 120px;-webkit-appearance:none;appearance:none;height:4px;border-radius:3px;
    background:rgba(120,180,200,.18);outline:none}
  .rng::-webkit-slider-thumb{-webkit-appearance:none;width:15px;height:15px;border-radius:50%;
    background:var(--sonar);cursor:pointer;box-shadow:0 0 10px -1px rgba(70,229,200,.7)}
  .rng::-moz-range-thumb{width:15px;height:15px;border:none;border-radius:50%;background:var(--sonar);cursor:pointer}
  .ctl-row .mono{width:40px;text-align:right;color:var(--foam);font-size:12px}
  .toggle{width:42px;height:24px;border-radius:13px;border:1px solid var(--line-strong);background:rgba(8,24,33,.6);
    position:relative;transition:.25s;flex-shrink:0}
  .toggle i{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--mist);transition:.25s}
  .toggle.on{background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));border-color:transparent}
  .toggle.on i{left:21px;background:#06141d}
  .retrain{margin-top:2px;padding:12px;border:none;border-radius:11px;font-weight:600;font-size:13.5px;color:#06141d;
    background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));box-shadow:0 6px 18px -6px rgba(70,229,200,.6);transition:transform .15s}
  .retrain:hover{transform:translateY(-1px)}
  .retrain.busy{opacity:.7;pointer-events:none}

  /* ===== strategy ===== */
  .strategy{padding:30px}
  .st-wrap{max-width:1240px;margin:0 auto;display:flex;flex-direction:column;gap:22px}
  .flow-panel{padding-bottom:14px}
  .flowgraph{width:100%}
  .flowgraph svg{width:100%;height:auto;display:block;overflow:visible}
  .node rect{transition:.3s}
  .node .nlabel{font-family:var(--body);font-weight:600;fill:var(--foam)}
  .node .nsub{font-family:var(--mono);fill:var(--mist-dim)}
  .node .nicon{fill:none;stroke-width:1.6}
  .wire{fill:none;stroke:rgba(120,180,200,.16);stroke-width:2}
  .wire.draw{stroke-dasharray:1;stroke-dashoffset:1}
  .flowgraph.in .wire.draw{animation:drawWire 1.1s var(--ease) forwards}
  @keyframes drawWire{to{stroke-dashoffset:0}}
  .flowpulse{fill:none;stroke:url(#wireGrad);stroke-width:2.4;stroke-linecap:round;
    stroke-dasharray:14 200;stroke-dashoffset:0;opacity:0}
  .flowgraph.in .flowpulse{opacity:1;animation:flowMove 2.6s linear infinite}
  @keyframes flowMove{to{stroke-dashoffset:-214}}
  .feedback{stroke-dasharray:5 7;opacity:.5}

  .st-grid{display:grid;grid-template-columns:1.25fr 1fr;gap:22px}
  .pred-demands{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
  .dchip{font-size:12.5px;color:var(--mist);background:transparent;border:1px solid var(--line-strong);
    border-radius:20px;padding:8px 13px;transition:.2s}
  .dchip:hover{color:var(--foam);border-color:var(--sonar);background:rgba(70,229,200,.06)}
  .dchip.active{color:#06141d;background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));border-color:transparent;font-weight:600}
  .scanner{position:relative;height:120px;border:1px solid var(--line);border-radius:12px;overflow:hidden;
    background:radial-gradient(120% 120% at 50% 0%, rgba(70,229,200,.05), transparent 70%);margin-bottom:16px}
  .scan-grid{position:absolute;inset:0;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:10px;padding:16px}
  .scan-grid .pt{width:7px;height:7px;border-radius:50%;background:rgba(120,180,200,.3);transition:.3s}
  .scan-grid .pt.hit{background:var(--sonar);box-shadow:0 0 10px var(--sonar);transform:scale(1.5)}
  .scan-beam{position:absolute;top:0;bottom:0;width:2px;left:-4px;
    background:linear-gradient(180deg,transparent,var(--sonar),transparent);box-shadow:0 0 18px 3px rgba(70,229,200,.5);opacity:0}
  .scan-beam.run{animation:beam 1.3s var(--ease)}
  @keyframes beam{0%{left:-4px;opacity:1}100%{left:100%;opacity:0}}
  .scan-hint{position:absolute;top:9px;left:50%;transform:translateX(-50%);font-size:11.5px;color:var(--mist);
    text-align:center;padding:5px 12px;border-radius:20px;background:rgba(8,24,33,.82);border:1px solid var(--line);
    backdrop-filter:blur(6px);white-space:nowrap;max-width:90%;overflow:hidden;text-overflow:ellipsis}
  .pred-results{display:flex;flex-direction:column;gap:9px}
  .pr{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:11px;padding:10px 12px;
    background:linear-gradient(180deg, rgba(15,42,56,.5), rgba(10,27,37,.3));animation:rise .5s var(--ease) both}
  .pr.top{border-color:rgba(70,229,200,.4);background:linear-gradient(180deg, rgba(70,229,200,.08), transparent)}
  .pr .ci{width:32px;height:32px;border-radius:9px;display:grid;place-items:center;font-family:var(--mono);font-size:11px;font-weight:600;color:#06141d;flex-shrink:0}
  .pr .pn{font-size:13.5px;font-weight:600}
  .pr .pm{font-size:11px;color:var(--mist);margin-top:1px}
  .pr .pbar{flex:0 0 90px;height:6px;border-radius:4px;background:rgba(120,180,200,.12);overflow:hidden;margin-left:auto}
  .pr .pbar i{display:block;height:100%;width:0;border-radius:4px;background:linear-gradient(90deg,var(--sonar-deep),var(--sonar));transition:width .9s var(--ease)}
  .pr .psc{font-family:var(--mono);font-size:13px;color:var(--sonar);width:42px;text-align:right;flex-shrink:0}
  .pr .crown{font-family:var(--mono);font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--sonar);
    border:1px solid rgba(70,229,200,.4);border-radius:5px;padding:2px 6px;flex-shrink:0}

  .road-panel .roadmap{position:relative}
  .roadmap svg{width:100%;height:auto;display:block;overflow:visible}
  #roadGlow{stroke-dasharray:1;stroke-dashoffset:1}
  .roadmap.in #roadGlow{animation:drawWire 2.4s var(--ease) forwards}
  #roadMarker{filter:drop-shadow(0 0 6px #46E5C8);opacity:0}
  .roadmap.in #roadMarker{opacity:1;offset-path:path("M40 40 C 220 40 220 130 230 150 C 245 180 60 190 60 230 C 60 280 380 250 420 320");
    animation:trace 7s linear infinite}
  @keyframes trace{from{offset-distance:0%}to{offset-distance:100%}}
  .roadmap .ms{fill:#0a1b25;stroke:var(--line-strong);stroke-width:1.5;transition:.3s}
  .roadmap .ms.lit{fill:#46E5C8;stroke:#46E5C8}
  .road-labels{position:absolute;inset:0;pointer-events:none}
  .road-labels .rl{position:absolute;transform:translate(-50%,0);font-family:var(--mono);font-size:9.5px;
    color:var(--mist);white-space:nowrap;text-shadow:0 1px 6px rgba(0,0,0,.8);opacity:0;transition:opacity .4s}
  .road-labels .rl.in{opacity:1}
  .road-labels .rl b{display:block;color:var(--foam);font-size:11px;font-weight:600;margin-bottom:1px}

  @media (max-width:1080px){
    .tabs{order:3;width:100%;margin:6px 0 0;justify-content:center}
    .ing-top,.ing-bottom,.st-grid{grid-template-columns:1fr}
  }
  @media (prefers-reduced-motion:reduce){
    *{animation-duration:.001s!important;transition-duration:.001s!important}
    .ring{animation:none}
    .flowpulse,#roadMarker{opacity:1}
  }
  /* ===== automation ===== */
  .automation{padding:30px}
  .au-wrap{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:22px}
  .au-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
  .au-actions{display:flex;gap:10px;flex-wrap:wrap}
  .au-run{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:600;color:#06141d;
    background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));border:none;border-radius:11px;padding:11px 18px;
    box-shadow:0 8px 22px -8px rgba(70,229,200,.7);transition:transform .15s}
  .au-run svg{width:15px;height:15px}
  .au-run:hover{transform:translateY(-1px)}
  .au-run.busy{opacity:.7;pointer-events:none}
  .au-ghost{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--mist);
    background:transparent;border:1px solid var(--line-strong);border-radius:11px;padding:11px 15px;transition:.2s}
  .au-ghost svg{width:15px;height:15px}
  .au-ghost:hover{color:var(--foam);border-color:var(--sonar)}
  .au-status{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;color:var(--mist);
    text-transform:uppercase;letter-spacing:.08em}
  .sdotled{width:8px;height:8px;border-radius:50%;background:var(--mist-dim);transition:.3s}
  .au-status.run .sdotled{background:var(--sonar);box-shadow:0 0 10px var(--sonar);animation:blip 1s infinite}
  .au-status.done .sdotled{background:var(--sonar)}
  @keyframes blip{50%{opacity:.4}}

  .au-grid{display:grid;grid-template-columns:1fr 340px;gap:22px;align-items:stretch}
  .au-main{display:flex;flex-direction:column;gap:22px;min-width:0}
  .au-canvas-panel{min-width:0}
  .auto-canvas{position:relative;width:100%}
  .auto-canvas svg{width:100%;height:auto;display:block;overflow:visible}
  .autowire{fill:none;stroke:rgba(120,180,200,.18);stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
  .autowire.draw{stroke-dasharray:1;stroke-dashoffset:1}
  .auto-canvas.in .autowire.draw{animation:drawWire 1s var(--ease) forwards}
  .autopulse{fill:none;stroke:url(#autoGrad);stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round;
    stroke-dasharray:16 240;opacity:0}
  .auto-canvas.in .autopulse{opacity:1;animation:flowMove 2.8s linear infinite}
  .autowire.hot{stroke:rgba(70,229,200,.5)}
  .wjoint{fill:#0a1b25;stroke:rgba(120,180,200,.35);stroke-width:1.4}

  .auto-nodes{position:absolute;inset:0;pointer-events:none}
  .anode{position:absolute;transform:translate(-50%,-50%);width:158px;pointer-events:auto;cursor:pointer;
    border:1px solid var(--line-strong);border-radius:13px;padding:11px 12px;
    background:linear-gradient(180deg, rgba(13,33,45,.96), rgba(9,24,33,.96));backdrop-filter:blur(4px);
    transition:border-color .25s, box-shadow .25s, transform .25s}
  .anode:hover{border-color:rgba(70,229,200,.5);transform:translate(-50%,-50%) translateY(-2px)}
  .anode.sel{border-color:var(--sonar);box-shadow:0 0 0 1px var(--sonar), 0 14px 30px -14px rgba(70,229,200,.6)}
  .anode.active{border-color:var(--sonar);box-shadow:0 0 22px -4px rgba(70,229,200,.7)}
  .anode .ah{display:flex;align-items:center;gap:9px}
  .anode .aic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;
    background:rgba(70,229,200,.1);border:1px solid rgba(70,229,200,.25)}
  .anode .aic svg{width:16px;height:16px;color:var(--sonar)}
  .anode.active .aic{background:var(--sonar);border-color:var(--sonar)}
  .anode.active .aic svg{color:#06141d}
  .anode .at{font-size:13px;font-weight:600;line-height:1.1}
  .anode .ann{font-family:var(--mono);font-size:8.5px;color:var(--mist-dim);letter-spacing:.05em;margin-top:2px}
  .anode .aapp{display:flex;align-items:center;gap:5px;margin-top:9px;font-family:var(--mono);font-size:9.5px;color:var(--mist)}
  .anode .aapp .achip{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:6px;
    padding:2px 6px;background:rgba(8,24,33,.6);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .anode .acount{position:absolute;top:-9px;right:-9px;min-width:22px;height:22px;padding:0 6px;border-radius:11px;
    background:#0a1b25;border:1px solid var(--sonar);color:var(--sonar);font-family:var(--mono);font-size:10px;
    display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.6);transition:.3s}
  .anode.counted .acount{opacity:1;transform:scale(1)}

  .funnel{display:flex;align-items:stretch;gap:6px;margin-top:18px;overflow-x:auto;scrollbar-width:none}
  .funnel::-webkit-scrollbar{display:none}
  .fstep{flex:1;min-width:74px;border:1px solid var(--line);border-radius:10px;padding:10px 8px;text-align:center;
    background:rgba(8,24,33,.4);position:relative}
  .fstep .fv{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.01em}
  .fstep .fl{font-family:var(--mono);font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--mist-dim);margin-top:3px}
  .fstep.dim .fv{color:var(--mist-dim)}

  .au-side{display:flex;flex-direction:column;gap:18px}
  .cfg-panel{padding:18px}
  .llm-list{display:flex;flex-direction:column;gap:9px}
  .llm{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:11px;padding:11px 12px;
    cursor:pointer;transition:.2s;background:rgba(8,24,33,.35)}
  .llm:hover{border-color:rgba(70,229,200,.4)}
  .llm.on{border-color:var(--sonar);background:rgba(70,229,200,.07)}
  .llm .lr{width:16px;height:16px;border-radius:50%;border:1.6px solid var(--line-strong);flex-shrink:0;display:grid;place-items:center;transition:.2s}
  .llm.on .lr{border-color:var(--sonar)}
  .llm.on .lr::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--sonar)}
  .llm .ln{font-size:13.5px;font-weight:600}
  .llm .lt{font-family:var(--mono);font-size:9.5px;color:var(--mist-dim);margin-top:2px}
  .llm .lbadge{margin-left:auto;font-family:var(--mono);font-size:8.5px;letter-spacing:.06em;text-transform:uppercase;
    padding:3px 7px;border-radius:6px}
  .llm .lbadge.local{color:var(--sonar);border:1px solid rgba(70,229,200,.35)}
  .llm .lbadge.api{color:var(--mist);border:1px solid var(--line)}
  .api-field{margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
  .api-field label{font-size:12px;color:var(--mist);display:block;margin-bottom:7px}
  .api-row{display:flex;gap:8px}
  .api-row input{flex:1;background:rgba(6,18,26,.7);border:1px solid var(--line-strong);border-radius:9px;
    padding:10px 11px;color:var(--foam);font-family:var(--mono);font-size:12px;outline:none}
  .api-row input:focus{border-color:var(--sonar)}
  .api-connect{background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));color:#06141d;border:none;
    border-radius:9px;padding:0 15px;font-weight:600;font-size:12.5px}
  .api-connect.ok{background:rgba(70,229,200,.15);color:var(--sonar);border:1px solid rgba(70,229,200,.4)}
  .api-note{font-size:11px;color:var(--mist-dim);margin-top:9px;line-height:1.5}

  .conn-list{display:flex;flex-direction:column;gap:9px}
  .conn{display:flex;align-items:center;gap:11px;border:1px solid var(--line);border-radius:11px;padding:10px 12px;background:rgba(8,24,33,.35)}
  .conn .cic{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;
    font-family:var(--mono);font-size:11px;font-weight:600;color:var(--foam);background:rgba(120,180,200,.1);border:1px solid var(--line)}
  .conn .cn{font-size:13px;font-weight:600}
  .conn .cc{font-family:var(--mono);font-size:9.5px;color:var(--mist-dim);margin-top:2px}
  .conn .cbtn{margin-left:auto;font-size:11.5px;font-weight:600;border-radius:8px;padding:6px 12px;transition:.2s;border:1px solid var(--line-strong);background:transparent;color:var(--mist)}
  .conn .cbtn:hover{color:var(--foam);border-color:var(--sonar)}
  .conn.connected .cbtn{color:var(--sonar);border-color:rgba(70,229,200,.4);background:rgba(70,229,200,.08)}
  .conn.connected .cic{background:rgba(70,229,200,.12);border-color:rgba(70,229,200,.3);color:var(--sonar)}

  .step-cfg{display:flex;flex-direction:column;gap:13px}
  .step-empty,.log-empty{font-size:12.5px;color:var(--mist-dim);line-height:1.55}
  .scfield label{font-size:11px;font-family:var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--mist-dim);display:block;margin-bottom:6px}
  .scfield input,.scfield select,.scfield textarea{width:100%;background:rgba(6,18,26,.7);border:1px solid var(--line-strong);
    border-radius:9px;padding:10px 11px;color:var(--foam);font-family:var(--body);font-size:13px;outline:none;transition:border-color .2s}
  .scfield input:focus,.scfield select:focus,.scfield textarea:focus{border-color:var(--sonar)}
  .scfield textarea{resize:vertical;min-height:58px;font-size:12.5px}
  .scfield select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238FAEBC' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}

  .log-panel{min-height:120px;flex:1 1 auto;display:flex;flex-direction:column}
  .runlog{display:flex;flex-direction:column;gap:6px;flex:1;min-height:0;overflow-y:auto;font-family:var(--mono);font-size:12px}
  .logline{display:flex;gap:10px;align-items:baseline;padding:7px 10px;border-radius:8px;background:rgba(8,24,33,.4);animation:rise .4s var(--ease) both}
  .logline .lt{color:var(--mist-dim);font-size:10px;flex-shrink:0}
  .logline .lm{color:var(--mist)}
  .logline.ok .lm{color:var(--foam)}
  .logline.hl{background:rgba(70,229,200,.08)}
  .logline.hl .lm{color:var(--sonar)}

  /* MCP config modal */
  .mcp-modal{position:fixed;inset:0;z-index:90;display:grid;place-items:center;padding:24px}
  .mcp-modal[hidden]{display:none}
  .mcp-backdrop{position:absolute;inset:0;background:rgba(3,9,13,.74);backdrop-filter:blur(5px);animation:mcpFade .2s}
  @keyframes mcpFade{from{opacity:0}to{opacity:1}}
  .mcp-dialog{position:relative;width:100%;max-width:470px;border:1px solid var(--line-strong);border-radius:18px;
    background:linear-gradient(180deg, rgba(13,33,45,.98), rgba(9,22,31,.98));
    box-shadow:0 40px 90px -30px rgba(0,0,0,.85);animation:cardIn .35s var(--ease) both;max-height:90vh;display:flex;flex-direction:column}
  .mcp-head{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line)}
  .mcp-ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-family:var(--mono);font-size:12px;
    font-weight:600;color:var(--sonar);background:rgba(70,229,200,.1);border:1px solid rgba(70,229,200,.3);flex-shrink:0}
  .mcp-htext{flex:1;min-width:0}
  .mcp-title{font-family:var(--display);font-weight:700;font-size:16px}
  .mcp-sub{font-family:var(--mono);font-size:10px;color:var(--mist-dim);margin-top:2px}
  .mcp-x{background:none;border:none;color:var(--mist-dim);padding:4px;display:grid;place-items:center;flex-shrink:0}
  .mcp-x svg{width:18px;height:18px}.mcp-x:hover{color:var(--foam)}
  .mcp-body{padding:18px 20px;display:flex;flex-direction:column;gap:13px;overflow-y:auto}
  .mcp-two{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .mcp-note{font-size:11px;color:var(--mist-dim);line-height:1.5}
  .mcp-foot{display:flex;align-items:center;gap:10px;padding:16px 20px;border-top:1px solid var(--line)}
  .mcp-foot-r{display:flex;gap:10px;margin-left:auto}
  .mcp-cancel{background:transparent;border:1px solid var(--line-strong);color:var(--mist);border-radius:10px;padding:10px 16px;font-size:13px;font-weight:500;transition:.2s}
  .mcp-cancel:hover{color:var(--foam);border-color:var(--mist-dim)}
  .mcp-go{background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));color:#06141d;border:none;border-radius:10px;padding:10px 18px;font-size:13.5px;font-weight:600;transition:transform .15s}
  .mcp-go:hover{transform:translateY(-1px)}
  .mcp-disconnect{background:transparent;border:1px solid rgba(255,130,130,.4);color:#FF8A8A;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:500;transition:.2s}
  .mcp-disconnect:hover{background:rgba(255,130,130,.08)}

  @media (max-width:1080px){
    .au-grid{grid-template-columns:1fr}
  }

  /* ===== login ===== */
  .login{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;
    background:
      radial-gradient(120% 90% at 18% -10%, rgba(70,229,200,.10), rgba(70,229,200,0) 55%),
      radial-gradient(100% 80% at 100% 110%, rgba(91,155,255,.09), rgba(91,155,255,0) 60%),
      var(--abyss);
    transition:opacity .6s var(--ease), visibility .6s}
  .login.out{opacity:0;visibility:hidden}
  .login-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
  .login-bg span{position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);border-radius:50%;
    border:1px solid rgba(70,229,200,.14)}
  .login-bg span:nth-child(1){width:360px;height:360px;animation:lpulse 6s ease-out infinite}
  .login-bg span:nth-child(2){width:360px;height:360px;animation:lpulse 6s ease-out infinite 2s}
  .login-bg span:nth-child(3){width:360px;height:360px;animation:lpulse 6s ease-out infinite 4s}
  @keyframes lpulse{0%{width:200px;height:200px;opacity:.5}100%{width:900px;height:900px;opacity:0}}
  .login-card{position:relative;width:100%;max-width:392px;border:1px solid var(--line-strong);border-radius:20px;
    padding:34px 32px;background:linear-gradient(180deg, rgba(13,36,49,.92), rgba(8,22,31,.92));
    backdrop-filter:blur(16px);box-shadow:0 40px 80px -30px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.04);
    animation:cardIn .7s var(--ease) both}
  @keyframes cardIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:none}}
  .login-card.shake{animation:shake .45s}
  @keyframes shake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}30%,50%,70%{transform:translateX(-7px)}40%,60%{transform:translateX(7px)}}
  .login-brand{display:flex;align-items:center;gap:12px}
  .login-brand .mark{width:36px;height:36px}.login-brand .mark svg{width:100%;height:100%}
  .lb-text{display:flex;flex-direction:column;line-height:1}
  .lb-text b{font-family:var(--display);font-weight:800;font-size:20px;letter-spacing:-.02em}
  .lb-text span{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--mist-dim);margin-top:3px}
  .login-firm{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--sonar-deep);margin:18px 0 0}
  .login-h{font-family:var(--display);font-weight:700;font-size:23px;letter-spacing:-.02em;margin:6px 0 4px}
  .login-sub{font-size:13px;color:var(--mist);margin-bottom:22px}
  .field{display:flex;align-items:center;gap:10px;border:1px solid var(--line-strong);border-radius:12px;
    padding:0 12px;background:rgba(6,18,26,.6);margin-bottom:12px;transition:border-color .2s}
  .field:focus-within{border-color:var(--sonar)}
  .field>svg{width:18px;height:18px;color:var(--mist-dim);flex-shrink:0}
  .field input{flex:1;background:transparent;border:none;outline:none;color:var(--foam);font-family:var(--body);
    font-size:14px;padding:13px 0}
  .field input::placeholder{color:var(--mist-dim)}
  .field .eye{background:none;border:none;color:var(--mist-dim);padding:4px;display:grid;place-items:center;transition:color .2s}
  .field .eye:hover{color:var(--foam)}.field .eye svg{width:18px;height:18px}
  .login-err{min-height:18px;font-size:12.5px;color:#FF7A7A;margin:2px 2px 10px;opacity:0;transition:opacity .2s}
  .login-err.on{opacity:1}
  .login-btn{width:100%;padding:13px;border:none;border-radius:12px;font-weight:600;font-size:14.5px;color:#06141d;
    background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));box-shadow:0 8px 22px -8px rgba(70,229,200,.7);
    transition:transform .15s}
  .login-btn:hover{transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}
  .login-foot{text-align:center;font-family:var(--mono);font-size:10px;color:var(--mist-dim);margin-top:18px;letter-spacing:.04em}

  /* ===== strategy analytics ===== */
  .st-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
  .export-btn{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--sonar);
    background:rgba(70,229,200,.07);border:1px solid rgba(70,229,200,.35);border-radius:11px;padding:10px 16px;
    transition:.2s;white-space:nowrap}
  .export-btn svg{width:16px;height:16px}
  .export-btn:hover{background:rgba(70,229,200,.14);border-color:var(--sonar)}
  .horizon{display:flex;align-items:center;gap:4px;flex-wrap:wrap;background:rgba(6,16,23,.6);
    border:1px solid var(--line);border-radius:12px;padding:5px;width:fit-content;max-width:100%}
  .hz-lab{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--mist-dim);padding:0 10px}
  .hzbtn{font-size:12.5px;color:var(--mist);background:transparent;border:none;padding:8px 14px;border-radius:8px;
    font-weight:500;white-space:nowrap;transition:.2s}
  .hzbtn:hover{color:var(--foam)}
  .hzbtn[aria-pressed="true"]{color:#06141d;background:linear-gradient(135deg,var(--sonar),var(--sonar-deep));
    box-shadow:0 4px 14px -4px rgba(70,229,200,.55);font-weight:600}

  .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
  .kpi{border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;
    background:linear-gradient(180deg, rgba(12,33,45,.55), rgba(9,26,36,.3));position:relative;overflow:hidden}
  .kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--sonar),transparent)}
  .kpi .kv{font-family:var(--display);font-weight:700;font-size:30px;letter-spacing:-.02em;line-height:1}
  .kpi .kl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--mist-dim);margin-top:8px}
  .kpi .kd{font-size:11.5px;color:var(--mist);margin-top:6px;min-height:16px}
  .kpi .kd .up{color:var(--sonar)}

  .st-grid2{display:grid;grid-template-columns:1.3fr 1fr;gap:22px}
  .chartwrap{position:relative}
  .chart{width:100%;height:auto;display:block;overflow:visible}
  .chart-x{display:flex;justify-content:space-between;font-family:var(--mono);font-size:9.5px;color:var(--mist-dim);margin-top:6px;padding:0 2px}
  .wf-area{opacity:.9}
  .wf-line{fill:none;stroke:url(#wfGrad);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
  .wf-rev{fill:none;stroke:#46E5C8;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
    transition:stroke-dashoffset 1s var(--ease)}
  .wf-dot{fill:#46E5C8;filter:drop-shadow(0 0 6px #46E5C8);transition:transform .8s var(--ease)}
  .wf-grid{stroke:rgba(120,180,200,.08);stroke-width:1}
  .wf-vline{stroke:rgba(70,229,200,.4);stroke-width:1;stroke-dasharray:3 4;transition:transform .8s var(--ease)}

  .drivers{display:flex;flex-direction:column;gap:13px}
  .driver .dh{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px}
  .driver .dn{font-size:13px;color:var(--foam);font-weight:500}
  .driver .dn small{color:var(--mist-dim);font-weight:400;font-size:11px;margin-left:6px}
  .driver .dv{font-family:var(--mono);font-size:11px;color:var(--mist)}
  .driver .dtrack{height:7px;border-radius:5px;background:rgba(120,180,200,.08);overflow:hidden}
  .driver .dfill{height:100%;width:0;border-radius:5px;transition:width 1s var(--ease)}

  .demand-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
  .dcell{border:1px solid var(--line);border-radius:12px;padding:14px;background:rgba(8,24,33,.4)}
  .dcell .dch{display:flex;align-items:center;gap:8px;margin-bottom:4px}
  .dcell .ddot{width:9px;height:9px;border-radius:3px;flex-shrink:0}
  .dcell .dname{font-size:13px;font-weight:600;color:var(--foam)}
  .dcell .dnums{display:flex;align-items:baseline;gap:8px;margin:8px 0 10px}
  .dcell .dnow{font-family:var(--mono);font-size:12px;color:var(--mist-dim)}
  .dcell .darrow{color:var(--mist-dim);font-size:11px}
  .dcell .dproj{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.01em}
  .dcell .dgrow{font-family:var(--mono);font-size:10px;color:var(--sonar);margin-left:auto;align-self:flex-end}
  .dcell .spark{height:30px;width:100%;display:block;overflow:visible}

  .matrix-grid{grid-template-columns:1.15fr .85fr}
  .matrix-wrap{position:relative}
  .matrix{width:100%;height:auto;display:block;overflow:visible}
  /* board brief (screen-hidden, print-only) */
  .print-brief{display:none}
  @media print{
    @page{size:A4;margin:14mm}
    body{background:#fff!important;color:#0a1b25!important}
    body>.shell,.veil,.print-brief~*{display:none!important}
    .print-brief{display:block!important;color:#0a1b25;font-family:var(--body)}
    .pb-head{border-bottom:2px solid #0a1b25;padding-bottom:12px;margin-bottom:18px}
    .pb-head .pb-brand{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:#46857a}
    .pb-head h1{font-family:var(--display);font-size:24px;margin:6px 0 4px}
    .pb-head .pb-sub{font-size:12px;color:#3a5563}
    .pb-kpis{display:flex;gap:14px;margin:16px 0}
    .pb-kpi{flex:1;border:1px solid #cfe0e6;border-radius:8px;padding:10px 12px}
    .pb-kpi .v{font-family:var(--display);font-weight:700;font-size:20px}
    .pb-kpi .l{font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#5e7c8a;margin-top:3px}
    .pb-sec{margin-top:18px;break-inside:avoid}
    .pb-sec h2{font-family:var(--display);font-size:14px;margin-bottom:8px;color:#0a1b25}
    .pb-table{width:100%;border-collapse:collapse;font-size:11px}
    .pb-table th{text-align:left;font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;
      color:#5e7c8a;border-bottom:1px solid #cfe0e6;padding:5px 6px}
    .pb-table td{padding:5px 6px;border-bottom:1px solid #eef4f6}
    .pb-table td.num{text-align:right;font-family:var(--mono)}
    .pb-invest{display:flex;flex-direction:column;gap:6px}
    .pb-invest .pi{font-size:11px;padding:7px 9px;border:1px solid #cfe0e6;border-radius:6px;break-inside:avoid}
    .pb-invest .pi b{font-size:12px}
    .pb-invest .pi .pw{color:#2c8c7c;display:block;margin-top:2px}
    .pb-cols{display:flex;gap:20px}
    .pb-cols>div{flex:1}
    .pb-foot{margin-top:20px;border-top:1px solid #cfe0e6;padding-top:8px;font-size:9.5px;color:#5e7c8a;
      display:flex;justify-content:space-between}
    .pb-dot{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:6px;vertical-align:middle}
  }

  .mdotg{transition:transform .9s var(--ease)}
  .mdotg .ringinvest{transition:opacity .5s var(--ease)}
  .mdot,.mz{transform-box:fill-box;transform-origin:center}
  .mdot{opacity:0;cursor:pointer;animation:dotIn .5s var(--ease) forwards;transition:r .15s}
  .mdot:hover{r:9}
  @keyframes dotIn{from{opacity:0;transform:scale(.2)}to{opacity:1;transform:scale(1)}}
  .mz{opacity:0;animation:zoneIn .7s var(--ease) forwards}
  @keyframes zoneIn{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}
  .matrix-tip{position:absolute;pointer-events:none;opacity:0;transform:translateY(4px);transition:.15s;
    background:rgba(8,24,33,.96);border:1px solid var(--line-strong);border-radius:9px;padding:8px 11px;
    min-width:150px;backdrop-filter:blur(8px);box-shadow:0 14px 26px -12px rgba(0,0,0,.8);z-index:3}
  .matrix-tip.on{opacity:1;transform:translateY(0)}
  .matrix-tip .mtn{font-size:12.5px;font-weight:600}
  .matrix-tip .mtm{font-family:var(--mono);font-size:10px;color:var(--mist);margin-top:3px}
  .matrix-tip .mtw{font-size:11px;color:var(--sonar);margin-top:5px}
  .matrix-legend{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:14px}
  .matrix-legend span{font-family:var(--mono);font-size:10px;color:var(--mist);display:flex;align-items:center;gap:6px}
  .matrix-legend i{width:8px;height:8px;border-radius:2px}

  .acq{display:flex;flex-direction:column;gap:11px;margin-bottom:18px}
  .acqrow{display:grid;grid-template-columns:120px 1fr 38px;align-items:center;gap:11px}
  .acqrow .an{font-size:12.5px;color:var(--mist);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .acqrow .at{height:8px;border-radius:5px;background:rgba(120,180,200,.08);overflow:hidden}
  .acqrow .af{height:100%;width:0;border-radius:5px;transition:width .9s var(--ease)}
  .acqrow .av{font-family:var(--mono);font-size:12px;color:var(--foam);text-align:right}
  .acqrow .av::before{content:"+"}
  .alloc{border-top:1px solid var(--line);padding-top:16px}
  .alloc-h{font-size:12.5px;color:var(--mist);margin-bottom:10px}
  .alloc-bar{display:flex;height:14px;border-radius:7px;overflow:hidden;background:rgba(120,180,200,.08)}
  .alloc-bar i{height:100%;width:0;transition:width 1s var(--ease)}
  .alloc-key{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:11px}
  .alloc-key span{font-family:var(--mono);font-size:10px;color:var(--mist);display:flex;align-items:center;gap:6px}
  .alloc-key i{width:8px;height:8px;border-radius:2px}

  @media (max-width:1080px){
    .kpis{grid-template-columns:repeat(2,1fr)}
    .st-grid2,.matrix-grid{grid-template-columns:1fr}
    .demand-grid{grid-template-columns:1fr 1fr}
  }
  @media (max-width:620px){
    .kpis,.demand-grid{grid-template-columns:1fr}
  }
