:root{
  --bg:#f0f4f8;--bg2:#e8eef6;--sur:#fff;--bdr:#dde3ed;--bdr2:#c8d2e0;
  --tx:#0d1b2a;--tx2:#4a5568;--mt:#8fa0b4;
  --ac:#1a56db;--acl:#eef3ff;
  --gn:#047857;--gnl:#ecfdf5;--gnb:#6ee7b7;
  --rd:#c81e1e;--rdl:#fff1f1;--rdb:#fca5a5;
  --yw:#b45309;--ywl:#fffbeb;--ywb:#fcd34d;
  --pp:#6d28d9;--ppl:#f5f3ff;
  --or:#c2410c;
  --sh:0 1px 3px rgba(0,0,0,.07),0 1px 2px rgba(0,0,0,.04);
  --sh2:0 4px 16px rgba(0,0,0,.08);
  --r:14px;--rs:10px;--rxs:7px;
  --mo:"JetBrains Mono",monospace;
  --sa:"Be Vietnam Pro",sans-serif;
  --nav:64px;--hdr:54px;
  --st:env(safe-area-inset-top,0px);
  --sb:env(safe-area-inset-bottom,0px);
  --apph:100dvh;
  --app-vvh:100dvh;
  --keyboard-offset:0px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;font-size:15px;-webkit-text-size-adjust:100%;background:var(--bg);overscroll-behavior:none}
body{height:var(--apph);min-height:var(--apph);background:var(--bg);color:var(--tx);font-family:var(--sa);line-height:1.5;
  overflow:hidden;overscroll-behavior:none}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:2px}
#app,#ob{min-height:var(--apph)}

/* ── HEADER ── */
.hdr{position:fixed;top:0;left:0;right:0;z-index:300;
  height:calc(var(--hdr) + var(--st));
  padding-top:var(--st);
  background:rgba(255,255,255,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;padding-left:16px;padding-right:12px;gap:10px}
.logo{font-size:17px;font-weight:800;letter-spacing:-.5px;white-space:nowrap;flex-shrink:0}
.logo em{color:var(--ac);font-style:normal}
.psel{flex:1;min-width:0;position:relative}
.pbtn{display:flex;align-items:center;gap:6px;padding:8px 13px;background:var(--bg2);
  border:1.5px solid var(--bdr2);border-radius:10px;cursor:pointer;max-width:210px;
  font-family:var(--sa);font-size:14px;font-weight:700;color:var(--tx);transition:.15s;
  min-height:40px}
.pbtn:active{border-color:var(--ac)}
.pbn{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
.pdd{position:absolute;top:calc(100% + 6px);left:0;min-width:230px;
  background:var(--sur);border:1.5px solid var(--bdr2);border-radius:var(--rs);
  box-shadow:0 12px 40px rgba(0,0,0,.13);z-index:400;overflow:hidden;display:none}
.pdd.op{display:block}
.pddi{padding:14px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;transition:.12s;min-height:46px}
.pddi:hover,.pddi:active{background:var(--bg2)}
.pddi.act{color:var(--ac);background:var(--acl)}
.pdds{height:1px;background:var(--bdr);margin:4px 0}
.pddnew{color:var(--ac);font-weight:700}
.hdra{display:flex;gap:6px;flex-shrink:0}
.ib{width:34px;height:34px;border-radius:50%;background:var(--bg2);border:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:.15s}
.ib:active{transform:scale(.92)}
.ib.sp{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── BOTTOM NAV ── */
.bnav{position:fixed;bottom:0;left:0;right:0;z-index:300;
  height:calc(var(--nav) + var(--sb));
  background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--bdr);
  display:flex;align-items:flex-start;padding-top:8px;
  padding-bottom:var(--sb);transition:transform .22s ease,opacity .22s ease;will-change:transform,opacity}
html.kb-open .bnav{transform:translateY(calc(100% + var(--sb)));opacity:0;pointer-events:none}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  gap:4px;cursor:pointer;transition:.15s;padding:5px 2px;
  font-size:10px;font-weight:700;color:var(--mt);letter-spacing:.3px;text-transform:uppercase;
  min-height:44px}
.ni.on{color:var(--ac)}
.ni .ic{font-size:20px;line-height:1;transition:.15s}
.ni.on .ic{transform:translateY(-1px)}

/* ── MAIN ── */
.main{
  height:var(--apph);
  padding-top:calc(var(--hdr) + var(--st) + 16px);
  padding-bottom:calc(var(--nav) + var(--sb) + 12px);
  padding-left:16px;padding-right:16px;
  max-width:700px;margin:0 auto;
  overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}
.pg{display:none;animation:fu .2s ease}
.pg.on{display:block}
@keyframes fu{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* ── CARDS ── */
.card{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--r);
  padding:18px 17px;margin-bottom:14px;box-shadow:var(--sh)}
.ct{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;
  color:var(--mt);margin-bottom:13px;display:flex;align-items:center;gap:6px}
.ch{display:flex;justify-content:space-between;align-items:center;margin-bottom:13px}

/* ── HERO ── */
.hero{background:linear-gradient(135deg,#1a3a6b 0%,#1a56db 55%,#0284c7 100%);
  border-radius:var(--r);padding:18px 16px 14px;margin-bottom:14px;
  box-shadow:0 8px 32px rgba(26,86,219,.22);position:relative;overflow:hidden;
  max-width:100%}
.hero::before{content:"";position:absolute;top:-50%;right:-15%;width:200px;height:200px;border-radius:50%;background:rgba(255,255,255,.05);pointer-events:none}
.hlrow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.hl{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:0}
.hrg{display:inline-flex;align-items:center;justify-content:center;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);font-size:10px;font-weight:700;letter-spacing:.3px;color:#fff;white-space:nowrap}.hrgwrap{position:relative;display:flex;flex-direction:column;align-items:flex-end}.hrgbtn{cursor:pointer}.hrgmenu{margin-top:8px;display:flex;flex-direction:column;gap:6px;padding:8px;border-radius:14px;background:rgba(8,22,48,.94);border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 28px rgba(2,6,23,.24);min-width:118px}.hrgopt{border:0;background:rgba(255,255,255,.06);color:#fff;padding:8px 10px;border-radius:10px;font-size:11px;font-weight:700;cursor:pointer;text-align:left}.hrgopt:hover{background:rgba(255,255,255,.12)}
.hpn{font-size:13px;font-weight:600;color:rgba(255,255,255,.78);margin:8px 0 2px}
.hv{font-size:38px;font-weight:800;color:#fff;letter-spacing:-1px;line-height:1.05;font-family:var(--mo)}
.hsb{font-size:12px;color:rgba(255,255,255,.74);margin-top:7px;font-weight:500;line-height:1.35}
.hsb-pnl{margin-top:8px;color:rgba(255,255,255,.82)}
.hmeta{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px}
.hmetaL{display:flex;align-items:baseline;gap:8px;min-width:0;flex-wrap:wrap}
.hmk{font-size:10px;font-weight:800;letter-spacing:.45px;text-transform:uppercase;color:rgba(255,255,255,.58)}
.hmv{font-size:12px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.hvt{display:inline-flex;align-items:center;justify-content:center;min-width:74px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:10px;font-weight:700;letter-spacing:.25px;cursor:pointer;transition:.15s}
.hvt.on{background:rgba(255,255,255,.16)}
.hrow{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}
.hchip{background:rgba(255,255,255,.11);border:1px solid rgba(255,255,255,.08);border-radius:11px;padding:10px 11px;min-height:68px;display:flex;flex-direction:column;justify-content:space-between}
.hcl{font-size:10px;color:rgba(255,255,255,.56);font-weight:700;letter-spacing:.4px;text-transform:uppercase;margin-bottom:2px}
.hcv{font-size:15px;font-weight:700;color:#fff;font-family:var(--mo);line-height:1.2}
.hkv{font-weight:700;color:#fff}
.hfx{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:6px;flex-wrap:wrap}
.hfxi{font-size:10.5px;color:rgba(255,255,255,.68);line-height:1.35}
.hfxi strong{color:#fff;font-weight:700}
.hhelp{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);color:#fff;font-size:10px;cursor:pointer;margin-left:4px;vertical-align:1px}
.hvnd{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.12)}
.hvndl{min-width:0;display:flex;flex-direction:column;gap:2px}
.hvndk{font-size:10px;color:rgba(255,255,255,.56);font-weight:700;letter-spacing:.4px;text-transform:uppercase}
.hvndv{font-size:12px;color:#fff;font-weight:700;line-height:1.35}
.hvndm{font-size:10px;color:rgba(255,255,255,.68);line-height:1.3}
.hicon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:#fff;cursor:pointer;font-size:14px;flex-shrink:0}
.hicon.off{opacity:.62}
.tipbubble{position:fixed;z-index:1200;max-width:240px;padding:9px 11px;border-radius:12px;background:#0f172a;color:#fff;font-size:12px;line-height:1.45;box-shadow:0 12px 28px rgba(15,23,42,.28)}
.seg{display:inline-flex;gap:6px;padding:4px;background:var(--bg2);border:1px solid var(--bdr);border-radius:999px}
.seg button{border:0;background:transparent;color:var(--tx);padding:7px 12px;border-radius:999px;font-size:11px;font-weight:700;cursor:pointer}
.seg button.on{background:#fff;box-shadow:0 1px 2px rgba(15,23,42,.08);color:var(--ac)}
.prefrow{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px}
.prefmeta{font-size:10.5px;color:var(--mt);margin-top:2px;line-height:1.45}
.fxbox{display:flex;flex-direction:column;gap:12px;padding:12px;border:1px solid var(--bdr);border-radius:12px;background:var(--bg2)}
.fxbox-compact{gap:10px;padding:12px 14px}
.fxrow-stack{align-items:flex-start}
.fxhead{flex:1;min-width:0}
.fxlabel{font-size:12px;font-weight:700;line-height:1.3}
.fxrow{display:flex;justify-content:space-between;align-items:center;gap:10px}
.fxmanual{display:none}
.fxmanual.on{display:block}
.fxmeta{font-size:11px;color:var(--mt);line-height:1.55}
.fxmeta-compact{display:flex;flex-direction:column;gap:3px}
.fxmeta-compact .fxline{color:var(--tx);font-weight:700}
.fxmeta-compact .fxsub{color:var(--mt)}
.fxmeta-compact .fxhint{color:var(--mt);font-size:10px}
.fxmanual label{display:block;margin-bottom:6px}
.fxmanual input{max-width:220px}
@media (max-width:640px){.fxrow-stack{flex-direction:column}.fxrow-stack .seg{width:100%}.fxrow-stack .seg button{flex:1}}
@media (max-width:380px){.hero{padding:16px 14px 13px}.hv{font-size:34px}.hrow{gap:7px}.hchip{min-height:64px;padding:9px 10px}.hcv{font-size:14px}.hmv{font-size:11px}.hvt{min-width:68px;padding:6px 9px}}

/* ── STAT GRID ── */
.sg{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-bottom:14px}
.sb{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--rs);padding:14px;box-shadow:var(--sh)}
.slb{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--mt);margin-bottom:5px;display:flex;align-items:center;gap:4px}
.sv{font-size:20px;font-weight:700;font-family:var(--mo);line-height:1}
.ss{font-size:11px;color:var(--mt);margin-top:3px;font-family:var(--mo)}

/* ── COLORS ── */
.cg{color:var(--gn)}.cr{color:var(--rd)}.cy{color:var(--yw)}.cb{color:var(--ac)}.cm{color:var(--mt)}
.bgg{background:var(--gnl);color:var(--gn)}.bgr{background:var(--rdl);color:var(--rd)}
.bgy{background:var(--ywl);color:var(--yw)}.bgb{background:var(--acl);color:var(--ac)}.bgp{background:var(--ppl);color:var(--pp)}

/* ── BADGE ── */
.bdg{display:inline-flex;align-items:center;padding:4px 9px;border-radius:20px;font-size:11px;font-weight:700;font-family:var(--mo)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 18px;border-radius:var(--rs);
  border:none;font-family:var(--sa);font-size:14px;font-weight:700;cursor:pointer;transition:.15s;
  min-height:44px}
.btn:active{transform:scale(.97)}
.bp{background:var(--ac);color:#fff;box-shadow:0 2px 8px rgba(26,86,219,.28)}.bp:hover{background:#1446c0}
.bg2{background:var(--bg2);color:var(--tx);border:1.5px solid var(--bdr2)}.bg2:hover{background:var(--bdr)}
.bd{background:var(--rdl);color:var(--rd);border:1px solid var(--rdb)}
.bgn{background:var(--gnl);color:var(--gn);border:1px solid var(--gnb)}
.bsm{padding:10px 14px;font-size:13px;border-radius:8px;min-height:40px}
.bxs{padding:8px 12px;font-size:12px;border-radius:7px;min-height:36px}
.bfl{width:100%;justify-content:center}
.bic{padding:9px;border-radius:8px;font-size:16px;min-height:36px}

/* ── TOGGLE ── */
.tg{display:flex;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:3px;gap:2px}
.tb{flex:1;padding:8px 12px;border-radius:8px;border:none;background:none;font-family:var(--sa);
  font-size:13px;font-weight:700;cursor:pointer;color:var(--mt);transition:.15s;text-align:center;white-space:nowrap;
  min-height:36px}
.tb.on{background:var(--sur);color:var(--ac);box-shadow:var(--sh)}

/* ── FORMS ── */
.fg{display:flex;flex-direction:column;gap:6px}
.fg label{font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--tx2)}
input,select{background:var(--bg2);border:1.5px solid var(--bdr);color:var(--tx);border-radius:var(--rs);
  padding:13px 14px;font-family:var(--mo);font-size:16px;outline:none;transition:border-color .15s;width:100%;
  min-height:46px}
input:focus,select:focus{border-color:var(--ac);background:#fff}
select option{background:#fff}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.fr3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:9px}

/* ── MODAL ── */
.mbg{display:none;position:fixed;inset:0;background:rgba(13,27,42,.52);z-index:500;
  align-items:flex-end;justify-content:center;touch-action:none;overscroll-behavior:none}
.mbg.on{display:flex;animation:fi .15s ease}
@keyframes fi{from{opacity:0}to{opacity:1}}
html.modal-open,html.modal-open body{overflow:hidden!important;height:100%!important}
.ms{background:var(--sur);border-radius:24px 24px 0 0;padding:22px 20px calc(22px + env(safe-area-inset-bottom));
  width:100%;max-width:700px;max-height:min(85dvh,calc(var(--apph) - 12px));overflow-y:auto;animation:su .2s ease;
  -webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}
html.modal-open.kb-open .mbg.on{align-items:flex-start;padding-top:max(8px,env(safe-area-inset-top))}
html.modal-open.kb-open .ms{max-height:calc(var(--apph) - max(8px,env(safe-area-inset-top)));
  padding-bottom:calc(220px + env(safe-area-inset-bottom))}
@keyframes su{from{transform:translateY(32px);opacity:0}to{transform:translateY(0);opacity:1}}
.mh{width:36px;height:4px;background:var(--bdr2);border-radius:2px;margin:0 auto 18px}
.mt2{font-size:18px;font-weight:800;margin-bottom:18px}

/* ── PROGRESS ── */
.pb{height:6px;background:var(--bg2);border-radius:3px;overflow:hidden}
.pf{height:100%;border-radius:3px;transition:width .35s cubic-bezier(.34,1.56,.64,1)}

/* ── ACCORDION ── */
.acc{border:1.5px solid var(--bdr);border-radius:var(--r);overflow:hidden;margin-bottom:14px}
.ach{display:flex;justify-content:space-between;align-items:center;padding:16px 17px;cursor:pointer;background:var(--sur);transition:.15s;min-height:52px}
.ach:hover,.ach:active{background:var(--bg2)}
.achl{display:flex;flex-direction:column;gap:2px}
.acht{font-size:15px;font-weight:700}
.achs{font-size:12px;color:var(--mt)}
.acar{font-size:11px;color:var(--mt);transition:transform .2s;flex-shrink:0}
.acar.on{transform:rotate(180deg)}
.acb{display:none;padding:16px;border-top:1px solid var(--bdr);background:var(--bg2)}
.acb.on{display:block}

/* ── ASSET CARD ── */
.ac{background:var(--sur);border:1px solid var(--bdr);border-radius:var(--rs);padding:16px 16px;margin-bottom:12px;box-shadow:var(--sh)}
.act{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}
.acn{font-size:15px;font-weight:800;letter-spacing:-.3px}
.acp{font-size:11px;color:var(--mt);margin-top:2px}
.acvr{text-align:right}
.acv{font-family:var(--mo);font-size:15px;font-weight:700}
.acvs{font-family:var(--mo);font-size:11px;margin-top:1px}
.acbot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:7px}
.acm{display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.acas{display:flex;gap:6px}

/* ── DCA ── */
.dcar{display:flex;gap:8px;align-items:center;margin-bottom:8px;padding:10px;background:var(--bg2);border-radius:9px;border:1px solid var(--bdr)}
.dcar input{padding:9px 10px;font-size:13px}
.dcd{width:34px;height:34px;border-radius:8px;border:none;background:var(--rdl);color:var(--rd);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}

/* ── PIE ── */
.piel{display:flex;gap:14px;align-items:center}
.piec{flex-shrink:0;width:155px;height:155px}
.pieg{flex:1;display:flex;flex-direction:column;gap:7px;min-width:0}
.lgi{display:flex;align-items:center;gap:8px}
.lgd{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.lgn{font-size:13px;font-weight:600;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lgv{font-family:var(--mo);font-size:12px;color:var(--tx2);flex-shrink:0}

/* ── RAIL CARD ── */
.rail{background:var(--sur);border:1.5px solid var(--bdr);border-radius:var(--r);margin-bottom:14px;overflow:hidden;box-shadow:var(--sh)}
.rail-h{padding:14px 16px;background:linear-gradient(90deg,var(--bg2),#f8faff);border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.rail-name{font-size:15px;font-weight:800}
.rail-meta{font-size:12px;color:var(--mt);font-family:var(--mo);margin-top:2px}
.rail-body{padding:0 16px 4px}
.rail-row{display:flex;align-items:center;gap:10px;padding:14px 0;border-bottom:1px solid var(--bdr)}
.rail-row:last-child{border-bottom:none}
.rail-tck{font-size:15px;font-weight:800;min-width:58px}
.rail-info{flex:1;min-width:0}
.rail-bar-row{display:flex;align-items:center;gap:6px;margin-top:5px}
.rail-pct{font-family:var(--mo);font-size:13px;font-weight:700}
.rail-tgt{font-family:var(--mo);font-size:12px;color:var(--mt)}
.rail-action{font-size:12px;font-family:var(--mo);font-weight:700;margin-top:5px}
.sig-buy{color:var(--gn)}.sig-sell{color:var(--rd)}.sig-ok{color:var(--mt)}.sig-warn{color:var(--yw)}

/* ── DEPOSIT ── */
.dep-card{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border:1.5px solid var(--gnb);border-radius:var(--r);padding:18px 17px;margin-bottom:14px}
.dep-title{font-size:14px;font-weight:800;color:var(--gn);margin-bottom:13px;display:flex;align-items:center;gap:7px}
.dep-row{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fff;border-radius:9px;border:1px solid #d1fae5;margin-bottom:8px}
.dep-tck{font-family:var(--mo);font-size:14px;font-weight:800;min-width:52px}
.dep-info{flex:1;min-width:0}
.dep-amt{font-family:var(--mo);font-size:14px;font-weight:800;color:var(--gn);flex-shrink:0;white-space:nowrap}

/* ── PERF ── */
.pfy{display:flex;align-items:center;gap:10px;padding:12px 13px;background:var(--bg2);border-radius:9px;border:1px solid var(--bdr);margin-bottom:8px}
.pfyl{font-family:var(--mo);font-size:13px;font-weight:600;color:var(--tx2);min-width:42px}
.pfv{font-family:var(--mo);font-size:13px;font-weight:700;min-width:54px;text-align:right}

/* ── HINT ── */
.hint{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--bg2);border:1px solid var(--bdr2);font-size:10px;color:var(--mt);cursor:help;position:relative;flex-shrink:0}
.hint:hover .hp,.hint:focus .hp,.hp.vis{display:block}
.hp{display:none;position:fixed;background:#1e293b;color:#fff;font-size:12px;padding:10px 13px;border-radius:10px;width:240px;max-width:85vw;text-align:left;z-index:600;line-height:1.55;font-family:var(--sa);font-weight:400;box-shadow:0 8px 32px rgba(0,0,0,.2);pointer-events:none;left:50%;top:auto;bottom:auto;transform:none}
.hp::after{display:none}

/* ── SRC DOT ── */
.sd{width:6px;height:6px;border-radius:50%;display:inline-block;margin-right:3px}
.sl2{background:var(--gn)}.sm{background:var(--yw)}.sf{background:var(--rd)}

/* ── SECTION HEAD ── */
.sech{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--mt);margin:18px 0 10px;display:flex;align-items:center;gap:8px}
.sech::after{content:"";flex:1;height:1px;background:var(--bdr)}

/* ── TEMPLATE ROW ── */
.trr{display:flex;gap:8px;align-items:center;margin-bottom:10px}
.trd{width:34px;height:34px;border-radius:8px;border:none;background:var(--rdl);color:var(--rd);cursor:pointer;font-size:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center}

/* ── ONBOARDING ── */
.ob{height:var(--apph);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px 20px calc(32px + env(safe-area-inset-bottom));background:var(--bg);overflow-y:auto;overscroll-behavior:contain}
.obl{font-size:40px;font-weight:800;letter-spacing:-2px;margin-bottom:7px}
.obl em{color:var(--ac);font-style:normal}
.obs{font-size:14px;color:var(--tx2);text-align:center;margin-bottom:32px;max-width:270px;line-height:1.65}
.obst{width:100%;max-width:380px;display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.obsp{background:var(--sur);border:1.5px solid var(--bdr);border-radius:var(--r);padding:15px;cursor:pointer;transition:.15s;display:flex;align-items:center;gap:13px}
.obsp:active{border-color:var(--ac);box-shadow:0 0 0 3px var(--acl)}
.obn{width:36px;height:36px;border-radius:50%;background:var(--acl);color:var(--ac);font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.obt strong{display:block;font-size:13px;font-weight:700}
.obt span{font-size:11px;color:var(--mt)}

/* ── TOAST ── */
.toast{position:fixed;bottom:calc(var(--nav) + var(--sb) + 12px);left:50%;transform:translateX(-50%) translateY(16px);background:#1e293b;color:#fff;padding:10px 18px;border-radius:20px;font-size:12px;font-weight:600;z-index:999;opacity:0;transition:all .22s,bottom .22s ease;pointer-events:none;white-space:nowrap}
html.kb-open .toast{bottom:12px}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── EMPTY ── */
.emp{text-align:center;padding:40px 20px;color:var(--mt)}
.empi{font-size:34px;margin-bottom:10px}
.empt{font-size:15px;font-weight:600;color:var(--tx2);margin-bottom:5px}
.emps{font-size:13px}

/* ── WARNING BOX ── */
.warn-box{font-size:12px;color:var(--yw);padding:10px 13px;background:var(--ywl);border-radius:9px;border:1px solid var(--ywb);line-height:1.6;margin-top:10px}
.info-box{font-size:12px;color:var(--ac);padding:10px 13px;background:var(--acl);border-radius:9px;border:1px solid #bfdbfe;line-height:1.6;margin-top:10px}

/* ── CW ── */
.cw{position:relative;width:100%;max-width:100%;overflow:hidden}
input[readonly]{cursor:not-allowed}


.hvndcard{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px;padding:10px 12px;border-radius:14px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.10)}
.hvndmain{min-width:0;display:flex;flex-direction:column;gap:4px}
.hvndttl{font-size:10px;color:rgba(255,255,255,.56);font-weight:700;letter-spacing:.45px;text-transform:uppercase}
.hvndval{font-size:16px;color:#fff;font-weight:800;line-height:1.2;font-family:var(--mo)}
.hvndmeta{font-size:10.5px;color:rgba(255,255,255,.68);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.hicon-vnd{width:auto;min-width:54px;height:32px;padding:0 12px;font-size:11px;font-weight:800;letter-spacing:.35px}
.hicon-vnd.off{opacity:.7}
.ddscrub{margin-top:10px;padding-top:2px}
.ddscrub-input{-webkit-appearance:none;appearance:none;width:100%;height:28px;background:transparent;margin:0}
.ddscrub-meta{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:4px;margin-top:8px}
.ddscrub-date{font-size:22px;font-weight:800;color:var(--tx);line-height:1.1;font-family:var(--mo)}
.ddscrub-tip{font-size:12px;color:var(--mt);text-align:left;line-height:1.4}
.ddscrub-input:focus{outline:none}
.ddscrub-input::-webkit-slider-runnable-track{height:4px;border-radius:999px;background:#d9e2ef}
.ddscrub-input::-moz-range-track{height:4px;border-radius:999px;background:#d9e2ef}
.ddscrub-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;margin-top:-6px;width:16px;height:16px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 2px 8px rgba(37,99,235,.35)}
.ddscrub-input::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#2563eb;border:2px solid #fff;box-shadow:0 2px 8px rgba(37,99,235,.35)}
.txhist-sheet{min-height:80dvh;max-height:94dvh;max-width:860px;padding:24px 22px calc(24px + env(safe-area-inset-bottom))}
.txhist-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.txhist-body{display:flex;flex-direction:column;gap:12px}
.txhist-close{margin-top:16px}
.txsum{padding:16px;border:1px solid var(--bdr);border-radius:18px;background:linear-gradient(180deg,#f8fbff,#f1f5fb)}
.txsum-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}
.txsum-title{font-size:20px;font-weight:800}
.txsum-sub{font-size:12px;color:var(--mt);margin-top:3px}
.txsum-last{font-size:12px;font-weight:700;color:var(--ac);background:#e8f0ff;border:1px solid #c7d7ff;padding:6px 10px;border-radius:999px}
.txsum-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.txmetric{padding:12px;border-radius:14px;background:#fff;border:1px solid var(--bdr);display:flex;flex-direction:column;gap:6px}
.txmetric-k{font-size:11px;color:var(--mt);font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.txmetric-v{font-size:16px;font-weight:800;font-family:var(--mo);color:var(--tx)}
.txrow{padding:14px 15px;border-radius:16px;border:1px solid var(--bdr);background:#fff;display:flex;flex-direction:column;gap:10px}
.txrow-buy{background:linear-gradient(180deg,#f5fff9,#eefbf4);border-color:#cfe8d8}
.txrow-sell{background:linear-gradient(180deg,#fff8f8,#fdf0f0);border-color:#f0d4d4}
.txrow-legacy{background:linear-gradient(180deg,#f8fbff,#eff4fb);border-color:#d7e3f5}
.txrow-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.txrow-date{font-size:11px;font-weight:800;letter-spacing:.4px;text-transform:uppercase;color:var(--mt)}
.txrow-actions{display:flex;gap:6px;flex-shrink:0}
.txbtn{padding:7px 11px;border-radius:999px;border:1px solid var(--bdr2);background:#fff;color:var(--tx);font-size:12px;font-weight:700;cursor:pointer}
.txbtn-del{border-color:#f0c6c6;background:#fff5f5;color:var(--rd)}
.txrow-main{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.txrow-type{font-size:16px;font-weight:800;color:var(--tx)}
.txrow-amt{font-size:13px;color:var(--tx2);margin-top:4px}
.txrow-total{font-size:16px;font-weight:800;font-family:var(--mo);white-space:nowrap;color:var(--tx)}
.txrow-meta{display:flex;flex-wrap:wrap;gap:8px 10px;font-size:12px;color:var(--mt)}
.txrow-meta span{padding:4px 8px;border-radius:999px;background:rgba(148,163,184,.10)}
@media (max-width:640px){
  .txhist-sheet{padding:20px 16px calc(20px + env(safe-area-inset-bottom))}
  .txsum-grid{grid-template-columns:1fr}
  .txrow-main{flex-direction:column;align-items:flex-start}
  .txrow-total{font-size:15px}
  .ddscrub-meta{flex-direction:column;align-items:flex-start}
}

/* v6.22 refinements */
.fxbox-compact{gap:12px;padding:14px 14px 12px}
.fxrow-stack{flex-direction:column;align-items:stretch;gap:10px}
.fxhead{display:flex;flex-direction:column;gap:4px}
.fxlabel{font-size:15px;font-weight:800;color:var(--tx)}
.prefmeta{font-size:12px;line-height:1.45;color:var(--mt);margin-top:0}
.fxrow-stack .seg{width:100%}
.fxrow-stack .seg button{flex:1;font-size:13px;padding:9px 12px}
.fxmanual{display:none}
.fxmanual.on{display:block}
.fxmanual-label{font-size:11px;font-weight:700;letter-spacing:.45px;text-transform:uppercase;color:var(--mt);margin-bottom:7px}
.fxmanual-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--bdr);border-radius:12px;background:#fff}
.fxmanual-prefix,.fxmanual-suffix{font-size:12px;font-weight:700;color:var(--tx2);white-space:nowrap}
.fxmanual input{flex:1;max-width:none;min-width:0;margin:0;text-align:center;font-family:var(--mo);font-size:20px;padding:12px 10px}
.fxmeta-compact{display:flex;flex-direction:column;gap:4px;padding:2px 2px 0}
.fxmeta-compact .fxline{font-size:15px;font-weight:800;color:var(--tx)}
.fxmeta-compact .fxsub{font-size:12px;color:var(--mt)}
.fxmeta-compact .fxhint{font-size:11px;color:var(--mt)}
.txhist-sheet{min-height:78dvh;max-height:94dvh;max-width:760px;padding:20px 18px calc(22px + env(safe-area-inset-bottom))}
.txhist-head{margin-bottom:14px}
.txhist-body{gap:10px}
.txsum{padding:12px;border-radius:16px}
.txsum-head{margin-bottom:10px}
.txsum-title{font-size:18px}
.txsum-sub{font-size:11px}
.txsum-last{font-size:11px;padding:5px 9px}
.txsum-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.txmetric{padding:10px 11px;border-radius:12px;gap:5px}
.txmetric-k{font-size:10px}
.txmetric-v{font-size:14px}
.txrow{padding:12px 13px;border-radius:14px;gap:8px}
.txrow-top{align-items:flex-start}
.txrow-date{font-size:12px;letter-spacing:.3px}
.txrow-actions{gap:5px}
.txbtn{padding:6px 10px;font-size:11px}
.txrow-main{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px}
.txrow-type{font-size:15px}
.txrow-amt{font-size:13px;margin-top:3px}
.txrow-total{font-size:17px}
.txrow-right{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.txrow-fee{font-size:11px;color:var(--mt);background:rgba(148,163,184,.10);padding:5px 8px;border-radius:999px}
.txrow-note{font-size:12px;color:var(--tx2);line-height:1.45;padding:8px 10px;border-radius:10px;background:rgba(255,255,255,.55);border:1px dashed rgba(148,163,184,.28)}
@media (max-width:640px){
  .txhist-sheet{padding:18px 14px calc(18px + env(safe-area-inset-bottom))}
  .txsum-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}
  .txmetric{padding:9px 8px}
  .txmetric-v{font-size:13px}
  .txrow-main{grid-template-columns:minmax(0,1fr) auto;gap:8px}
  .txrow-total{font-size:16px}
  .fxmanual-row{gap:8px;padding:10px}
  .fxmanual input{font-size:18px;padding:11px 8px}
}
@media (max-width:420px){
  .hrgmenu{min-width:108px}
  .txsum-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .txmetric-k{font-size:9.5px}
  .txmetric-v{font-size:12px}
  .txrow{padding:11px 12px}
  .txbtn{padding:5px 9px}
}


/* v6.24 refinements */
.hrgwrap{position:relative}
.hrgbtn{min-width:54px;position:relative;z-index:2}
.hrgmenu{
  position:absolute;top:calc(100% + 8px);right:0;z-index:7;
  display:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;
  width:188px;padding:10px;border-radius:16px;
  background:rgba(248,250,252,.96);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.55);box-shadow:0 12px 28px rgba(2,6,23,.18)
}
.hrgopt{
  background:#eef3fb;color:#16315f;padding:11px 10px;border-radius:12px;font-size:12px;
  font-weight:800;text-align:center;transition:.15s
}
.hrgopt.on,.hrgopt:active{background:#1a56db;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}
.hrgopt-wide{grid-column:1/-1}
.hvndcard{
  margin-top:10px;padding:10px 12px;border-radius:16px;cursor:pointer;
  transition:.18s ease;min-height:60px
}
.hvndcard:hover{background:rgba(255,255,255,.12)}
.hvndcard .hvndmeta{display:none}
.hvndcard.is-open .hvndmeta{display:block}
.hvndline{display:flex;align-items:center;gap:8px;min-width:0}
.hvndchev{
  font-size:10px;font-weight:800;letter-spacing:.3px;color:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:3px 8px;flex-shrink:0
}
.hvndcard:not(.is-open){padding-top:9px;padding-bottom:9px}
.hvndcard:not(.is-open) .hvndval{font-size:15px}
.hicon-vnd{min-width:70px}
.ddscrub{margin-top:8px}
.ddscrub-input{margin-bottom:6px}
.ddscrub-summary{
  width:100%;border:1px solid var(--bdr);background:#fff;border-radius:18px;
  padding:14px 16px;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  text-align:left;cursor:pointer;transition:.15s
}
.ddscrub-summary:active{transform:scale(.995)}
.ddscrub-head{min-width:0;display:flex;flex-direction:column;gap:5px}
.ddscrub-date{font-size:20px}
.ddscrub-tip{font-size:13px}
.ddscrub-open{
  flex-shrink:0;font-size:11px;font-weight:800;color:var(--ac);
  padding:8px 11px;border-radius:999px;background:#eef3fb;border:1px solid #d9e5fb
}
.ddscrub-panel{
  margin-top:8px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;
  padding:12px;border-radius:16px;background:#f8fbff;border:1px solid var(--bdr)
}
.ddpill{
  display:flex;align-items:center;gap:8px;padding:10px 11px;border-radius:12px;
  background:#fff;border:1px solid var(--bdr);min-width:0
}
.ddpill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.ddpill-k{font-size:12px;font-weight:700;color:var(--tx);min-width:0}
.ddpill-v{margin-left:auto;font-size:12px;font-family:var(--mo);color:var(--tx);white-space:nowrap}
.txrow-main{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end}
.txrow-right{align-items:flex-end;justify-content:flex-end}
.fxbox-compact{padding:14px}
.fxrow-stack{gap:10px}
.fxmanual{display:none}
.fxmanual.on{display:block}
.fxmanual-label{font-size:11px;font-weight:800;letter-spacing:.45px;text-transform:uppercase;color:var(--mt);margin-bottom:8px}
.fxmanual-row{
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;
  padding:10px 12px;border-radius:16px;background:#fff;border:1px solid var(--bdr)
}
.fxmanual-prefix,.fxmanual-suffix{font-size:12px;font-weight:800;color:var(--tx2);white-space:nowrap}
.fxmanual input{
  width:100%;max-width:none;height:52px;border-radius:14px;border:1px solid var(--bdr);
  background:#eef3fb;font-size:22px;font-family:var(--mo);font-weight:800;text-align:center;
  padding:0 10px
}
.fxmeta-compact{margin-top:10px}
.fxmeta-compact .fxsub{font-size:12px;line-height:1.45}
@media (max-width:640px){
  .hrgmenu{width:176px}
  .ddscrub-panel{grid-template-columns:1fr}
  .txrow-main{grid-template-columns:1fr;gap:8px}
  .txrow-right{align-items:flex-start}
}
@media (max-width:420px){
  .hvndcard{padding:9px 10px}
  .ddscrub-summary{padding:12px 13px}
  .ddscrub-date{font-size:18px}
  .fxmanual-row{grid-template-columns:1fr}
  .fxmanual-prefix,.fxmanual-suffix{font-size:11px}
  .fxmanual input{font-size:20px;height:48px}
}



.csvimp{display:flex;flex-direction:column;gap:10px}
.csvimp-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.csvstat{background:var(--bg2);border:1px solid var(--bdr);border-radius:12px;padding:10px 11px}
.csvstat-k{font-size:11px;color:var(--mt);margin-bottom:4px}
.csvstat-v{font-size:18px;font-weight:800}
.csvimp-breakdown{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:12px;color:var(--tx2)}
.csvimp-cash{font-size:12px;color:var(--tx2)}
.csvimp-cash .pos{color:var(--gr)}
.csvimp-cash .neg{color:var(--rd)}
.csvimp-note{font-size:12px;color:var(--mt)}
.csverrs{display:flex;flex-direction:column;gap:6px}
.csverr-row{font-size:12px;padding:8px 10px;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;color:var(--tx2)}

/* ── Rebalance template UX ── */
.rb-helper{font-size:12px;color:var(--mt);line-height:1.55;margin-bottom:10px}
.rb-card{padding:14px}
.rb-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}
.rb-template-head{width:100%;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;border:0;background:transparent;padding:0;margin-bottom:10px;text-align:left}
.rb-template-head-side{display:flex;align-items:center;gap:8px}
.rb-template-chevron{font-size:16px;color:var(--mt);line-height:1}
.rb-template-collapsed-summary{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--tx2);font-family:var(--mo)}
.rb-card-title{font-size:15px;font-weight:800}
.rb-card-sub{font-size:11px;color:var(--mt);line-height:1.5;margin-top:2px}
.rb-sum-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}
.rb-sum-box{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:9px}
.rb-sum-label{font-size:10px;color:var(--mt);text-transform:uppercase;font-weight:700;letter-spacing:.4px}
.rb-sum-val{font-size:14px;font-family:var(--mo);font-weight:700}
.rb-date{font-size:11px}
.rb-actions{display:flex;gap:8px;flex-wrap:wrap}

.rb-progress-wrap{margin-top:8px}
.rb-progress-label{display:flex;justify-content:space-between;gap:8px;font-size:12px;color:var(--tx2);font-weight:700;margin-bottom:6px}
.rb-progress{height:8px;border-radius:999px;background:var(--bg2);border:1px solid var(--bdr);overflow:hidden}
.rb-progress-fill{height:100%;border-radius:999px}
.rb-progress-fill.ok{background:var(--gr)}
.rb-progress-fill.warn{background:var(--yw)}
.rb-plan-input-wrap{margin:10px 0 8px}
.rb-plan-label{display:block;font-size:12px;font-weight:700;color:var(--tx2);margin-bottom:6px}
.rb-plan-input-row{display:flex;align-items:center;gap:8px}
.rb-plan-input{flex:1;min-width:0;font-size:16px;min-height:44px}
.rb-plan-unit{font-size:12px;font-weight:700;color:var(--mt)}
.rb-group-row.compact{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}
.rb-group-main{min-width:0}
.rb-group-actions{display:flex;gap:6px;justify-content:flex-end;align-items:flex-start;grid-column:2;grid-row:1/span 2;flex-wrap:wrap}
.rb-group-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.rb-group-row{display:flex;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--bdr);border-radius:10px;background:var(--sur)}
.rb-accordion{padding:0;overflow:hidden}
.rb-accordion-head{width:100%;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:12px;background:transparent;border:none;text-align:left}
.rb-acc-summary{font-size:12px;color:var(--tx2);margin:2px 0 6px;font-family:var(--mo)}
.rb-acc-side{display:flex;align-items:center;gap:8px}
.rb-acc-warn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;background:var(--ywl);color:var(--yw);font-size:12px;font-weight:800;border:1px solid var(--ywb)}
.rb-acc-chevron{font-size:16px;color:var(--mt);line-height:1}
.rb-accordion-body{padding:0 12px 12px}
.rb-gname{font-weight:800;font-size:13px;margin-bottom:5px}
.rb-chip-row{display:flex;flex-wrap:wrap;gap:5px}
.rb-chip{display:inline-flex;padding:3px 7px;border-radius:999px;background:var(--bg2);border:1px solid var(--bdr);font-size:11px}
.rb-metrics{display:flex;flex-direction:column;gap:3px;align-items:flex-start;font-size:11px;font-family:var(--mo)}
.rb-editor-wrap{display:flex;flex-direction:column;gap:12px;margin-top:10px}
.rb-editor-sec{background:#fff;border:1px solid var(--bdr);border-radius:14px;padding:12px}
.rb-editor-sec-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.rb-editor-sec-title{font-size:13px;font-weight:800;color:var(--tx)}
.rb-editor-list{display:flex;flex-direction:column;gap:8px}
.rb-editor-card{border:1px solid var(--bdr);border-radius:12px;padding:10px;background:var(--sur)}
.rb-editor-head{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:8px;align-items:center}
.rb-inline{display:flex;gap:6px;align-items:center}
.rb-input{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:8px 10px;font-size:13px;min-height:38px}
.rb-name-input-compact{min-height:48px;font-size:16px}
.rb-name-input{width:100%}
.rb-target-inline{min-width:112px}
.rb-target-input{width:78px;text-align:right}
.rb-target-readonly{justify-content:flex-end;background:var(--bg2);border:1px solid var(--bdr);padding:8px 10px;border-radius:10px;min-height:38px}
.rb-target-unit{font-weight:700;color:var(--mt);font-size:12px}
.rb-lbl{font-size:11px;color:var(--mt);font-weight:700;margin:8px 0 6px}
.rb-mapped-chips{margin-top:6px}
.rb-rail-pills{display:flex;flex-wrap:wrap;gap:6px}
.rb-rail-pill{border:1px solid var(--bdr);background:var(--bg2);color:var(--tx2);padding:6px 10px;border-radius:999px;font-size:11px}
.rb-rail-pill.on{border-color:var(--ac);color:var(--ac);background:var(--acl)}
.rb-rail-pills-compact .rb-rail-pill{font-size:12px;padding:7px 10px}
.rb-asset-map-list{display:flex;flex-direction:column;gap:6px}
.rb-map-row{min-height:40px;border:1px solid var(--bdr);border-radius:12px;background:var(--sur);padding:5px 9px;display:flex;align-items:center;justify-content:space-between;gap:8px;overflow:hidden}
.rb-map-ticker{font-size:12px;font-weight:700;min-width:0;flex:1;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
.rb-map-select{height:34px;max-width:146px;width:100%;border:1px solid var(--bdr);border-radius:10px;background:var(--bg2);padding:0 8px;font-size:13px;flex:0 0 146px}
.rb-map-target{flex:0 0 110px;justify-content:flex-end}
.rb-map-target-input{width:92px;text-align:right;font-size:16px}
.rb-unmapped{margin-top:10px;padding:10px;border-radius:12px;background:var(--ywl);border:1px solid var(--ywb);font-size:12px;color:var(--yw)}
.rb-unmapped-title{font-size:12px;font-weight:800;margin-bottom:7px}
.rb-editor-footer{position:static;bottom:auto;margin-top:12px;background:transparent;padding:0;border:0;border-radius:0;justify-content:flex-end;box-shadow:none}
#pg-rb.rb-keyboard-open .rb-editor-footer{
  position:static;
  bottom:auto;
  box-shadow:none;
  margin-top:12px;
}
#pg-rb.rb-keyboard-open .rb-editor-wrap{
  padding-bottom:140px;
}
.rb-editor-screen{display:flex;flex-direction:column;gap:12px;margin-top:10px;min-height:min(calc(100dvh - 220px),760px)}
.rb-editor-screen-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.rb-editor-title{font-size:18px;font-weight:800}
.rb-editor-back{white-space:nowrap}
.rb-editor-screen-content{display:flex;flex-direction:column;gap:10px;min-width:0}
.rb-editor-page-footer{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px;padding-bottom:calc(8px + env(safe-area-inset-bottom))}
.rb-target-summary{background:var(--bg2);border:1px solid var(--bdr);border-radius:12px;padding:10px 12px;margin-bottom:2px}
.rb-target-k{font-size:11px;font-weight:700;color:var(--mt)}
.rb-target-v{font-size:22px;line-height:1.15;font-family:var(--mo);font-weight:800;color:var(--tx);margin-top:3px}
.rb-target-sub{font-size:12px;color:var(--mt);margin-top:2px}
.rb-link-btn{border:none;background:transparent;color:var(--ac);font-size:13px;font-weight:700;padding:2px 0}
.rb-picker-wrap{margin-top:8px;border:1px solid var(--bdr);border-radius:12px;padding:8px;background:var(--bg2)}
.rb-picker-list{margin-top:8px;max-height:144px;overflow:auto}
.rb-empty-state{border:1px dashed var(--bdr);border-radius:12px;padding:12px;background:var(--bg2);display:flex;flex-direction:column;gap:5px}
.rb-empty-title{font-size:13px;font-weight:800}
.rb-map-row-compact{gap:7px}
.rb-map-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.rb-map-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.rb-del-btn{border:none;background:transparent;color:var(--rd);font-size:12px;font-weight:700;padding:0}
.rb-sheet-sec{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:10px;margin-bottom:8px;font-size:12px;line-height:1.6}
.rb-step-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;background:var(--acl);border:1px solid #cfe0ff;color:var(--ac);font-size:11px;font-weight:800;margin-bottom:8px}
.rb-asset-head{margin-bottom:8px}
.rb-asset-title{font-size:20px;font-weight:800;line-height:1.1;margin-bottom:6px}
.rb-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px}
.rb-detail-grid>div{background:#fff;border:1px solid var(--bdr);border-radius:10px;padding:8px}
.rb-detail-grid span{display:block;font-size:10px;color:var(--mt);text-transform:uppercase;font-weight:700}
.rb-detail-grid strong{display:block;font-size:13px;color:var(--tx2);margin-top:3px;word-break:break-word}
.rb-detail-grid-compact strong{font-size:12px}
.rb-trigger-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.rb-trigger-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.rb-inline-note{margin-top:8px;padding:8px 10px;border-radius:10px;background:#fff;border:1px dashed var(--bdr);font-size:12px;line-height:1.4}
.rb-tone-red{color:var(--rd)!important}
.rb-tone-blue{color:var(--ac)!important}
.rb-tone-neutral{color:var(--mt)!important}
.rb-sheet-note{padding:8px 10px;line-height:1.4}
.rb-asset-actions{padding-bottom:calc(4px + env(safe-area-inset-bottom))}
.rb-rail-asset-popup .ms{max-width:520px;padding:12px 12px calc(12px + env(safe-area-inset-bottom));background:#fff}
.rb-rail-asset-popup #actionPopupTitle{display:none}
.rb-rail-asset-popup #actionPopupDefaultFooter{display:none}
.rb-rail-asset-sheet{display:flex;flex-direction:column;gap:8px}
.rb-rail-asset-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}
.rb-rail-asset-id{display:flex;align-items:center;gap:10px;min-width:0}
.rb-rail-asset-icon{width:34px;height:34px;border-radius:999px;border:1px solid var(--bdr);background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.rb-rail-asset-title{font-size:17px;font-weight:800;line-height:1.2}
.rb-rail-asset-sub{font-size:12px;color:var(--mt);margin-top:2px}
.rb-rail-asset-close{border:1px solid var(--bdr);background:#fff;border-radius:999px;width:30px;height:30px;font-size:14px;color:var(--tx2)}
.rb-rail-asset-sec{border:1px solid var(--bdr);border-radius:10px;background:#fff;padding:9px}
.rb-rail-asset-sec-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:7px}
.rb-rail-asset-sec-title{font-size:12px;font-weight:800;margin-bottom:7px}
.rb-rail-asset-sec-head .rb-rail-asset-sec-title{margin-bottom:0}
.rb-rail-asset-grid4,.rb-rail-asset-grid3,.rb-rail-asset-grid2{display:grid;gap:0;border:1px solid var(--bdr);border-radius:8px;overflow:hidden;background:#fff}
.rb-rail-asset-grid4{grid-template-columns:repeat(4,minmax(0,1fr))}
.rb-rail-asset-grid3{grid-template-columns:repeat(3,minmax(0,1fr))}
.rb-rail-asset-grid2{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:6px}
.rb-rail-asset-cell{padding:7px 6px;border-right:1px solid var(--bdr);min-width:0}
.rb-rail-asset-cell:last-child{border-right:none}
.rb-rail-asset-cell span{display:block;font-size:10px;color:var(--mt);font-weight:700;line-height:1.2}
.rb-rail-asset-cell strong{display:block;margin-top:2px;font-size:12px;line-height:1.25;word-break:break-word}
.rb-rail-asset-note{margin-top:6px;border:1px solid var(--bdr);border-radius:8px;padding:7px 8px;font-size:11px;color:var(--tx2);line-height:1.35;background:var(--bg2)}
.rb-rail-asset-note-sec{padding:8px 9px}
.rb-rail-asset-note-text{font-size:12px;color:var(--tx2)}
.rb-rail-asset-trigger-wrap{margin-top:7px;padding:8px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg2)}
.rb-rail-asset-trigger-labels{display:flex;justify-content:space-between;gap:8px;font-size:10px;color:var(--mt);font-weight:700;margin-bottom:6px}
.rb-rail-asset-trigger-labels span:nth-child(2){text-align:center;flex:1}
.rb-rail-asset-trigger{height:10px;border:1px solid var(--bdr);border-radius:999px;display:flex;position:relative;overflow:hidden;margin-top:0;background:#fff}
.rb-rail-asset-trigger-zone{flex:1}
.rb-rail-asset-trigger-left{background:#e8f7ef}
.rb-rail-asset-trigger-mid{background:#e7f0ff}
.rb-rail-asset-trigger-right{background:#fdecec}
.rb-rail-asset-trigger-dot{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:999px;background:var(--ac);border:2px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.1)}
.rb-rail-asset-chip-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.rb-rail-asset-chip{display:inline-flex;padding:4px 8px;border-radius:999px;border:1px solid var(--bdr);font-size:11px;background:var(--bg2)}
.rb-rail-asset-footer{padding:4px 0 calc(4px + env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:6px}
.rb-rail-asset-footer-close{border:none;background:transparent;color:var(--mt);font-size:13px;font-weight:700;padding:4px 0}
.rb-row-mini{display:flex;justify-content:space-between;gap:8px;align-items:center;padding:7px 0;border-top:1px dashed var(--bdr)}
.rb-row-mini:first-child{border-top:none;padding-top:0}
.rb-overview-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.rb-metric-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:10px}
.rb-metric-item{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:8px}
.rb-metric-label{font-size:10px;color:var(--mt);text-transform:uppercase;font-weight:700}
.rb-metric-value{font-size:13px;font-weight:800;font-family:var(--mo)}
.rb-table{border:1px solid var(--bdr);border-radius:10px;overflow:hidden}
.rb-table-head,.rb-table-row{display:grid;grid-template-columns:minmax(150px,2fr) .9fr .9fr .9fr auto;gap:8px;padding:8px 10px;align-items:center}
.rb-table-head{background:var(--bg2);font-size:11px;color:var(--mt);font-weight:800}
.rb-table-row{border-top:1px solid var(--bdr);font-size:12px}
.rb-table-row:first-of-type{border-top:0}
.rb-cell-right{text-align:right;font-family:var(--mo)}
.rb-table-action{justify-self:end}
.rb-r67-status{border:1px solid #bbf7d0;border-radius:14px;padding:12px;background:#f0fdf4;margin:8px 0}
.rb-r67-status.warn{border-color:#fde68a;background:#fffbeb}
.rb-r67-status-title{font-weight:800;font-size:15px}
.rb-r67-status-line{font-size:12px;color:var(--tx2);margin-top:2px}
.rb-r67-cards{display:flex;flex-direction:column;gap:10px;margin-top:10px}
.rb-r67-card{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:12px;text-align:left;box-shadow:0 2px 8px rgba(15,23,42,.05)}
.rb-r67-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.rb-r67-name{font-weight:800}
.rb-r67-right{display:flex;gap:8px;align-items:center}
.rb-r67-pill{font-size:11px;font-weight:700;padding:4px 8px;border-radius:999px}
.rb-r67-pill.hold{background:#dcfce7;color:#166534}
.rb-r67-pill.buy{background:#dbeafe;color:#1d4ed8}
.rb-r67-pill.sell{background:#fee2e2;color:#b91c1c}
.rb-r67-detail{font-size:12px;color:var(--mt)}
.rb-r67-metrics{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-top:9px}
.rb-r67-metrics span{display:block;font-size:10px;color:var(--mt)}
.rb-r67-metrics strong{font-size:12px}
.rb-r67-note{margin-top:8px;font-size:12px;color:var(--tx2)}
.rb-threshold-bar{position:relative;height:8px;border-radius:999px;background:#e2e8f0;margin-top:8px}
.rb-threshold-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:12px;height:12px;border-radius:999px;background:var(--ac)}
.rb-threshold-scale{display:flex;justify-content:space-between;font-size:10px;color:var(--mt);margin-top:4px}
.rb-trigger{height:8px;background:linear-gradient(90deg,var(--gnl),var(--acl),var(--rdl));border:1px solid var(--bdr);border-radius:999px;position:relative;margin:8px 0}
.rb-trigger-bar{position:absolute;top:-3px;width:10px;height:14px;background:var(--ac);border-radius:4px;transform:translateX(-50%)}
.rb-rail-immediate-box{padding:10px 12px}
.rb-rail-immediate-title{font-size:12px;font-weight:800;margin-bottom:8px}
.rb-rail-immediate-cols{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.rb-rail-immediate-label{font-size:11px;font-weight:800;color:var(--tx2);margin-bottom:4px}
.rb-rail-immediate-list{margin:0;padding-left:16px;display:flex;flex-direction:column;gap:4px;font-family:var(--mo);font-size:12px}
.rb-rail-immediate-empty{font-size:12px;color:var(--tx2)}
.rb-rail-detail-view{padding-bottom:calc(72px + env(safe-area-inset-bottom))}
.rb-rail-row-list{display:flex;flex-direction:column;gap:8px}
.rb-rail-group-sec{display:flex;flex-direction:column;gap:8px}
.rb-rail-group-head{display:flex;justify-content:space-between;align-items:flex-end;gap:8px;padding:2px 2px 0}
.rb-rail-row-card{border:1px solid var(--bdr);border-radius:12px;background:#fff;padding:10px}
.rb-rail-row-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.rb-rail-row-head .rb-gname{overflow-wrap:anywhere;word-break:break-word}
.rb-rail-row-pct{margin-top:8px;font-size:16px;font-weight:800;font-family:var(--mo)}
.rb-rail-row-drift{margin-top:4px;font-size:12px;color:var(--tx2)}
.rb-rail-row-action{margin-top:8px;font-size:12px;color:var(--tx2);line-height:1.5;overflow-wrap:anywhere}
.rb-rail-row-cta{margin-top:8px;display:flex;justify-content:flex-end}
.rb-rail-note-box{margin-top:10px;font-size:12px}
.rb-manual-wrap{display:flex;flex-direction:column;gap:10px}
.rb-manual-block{border:1px solid var(--bdr);border-radius:10px;background:#fff;padding:10px}
.rb-manual-head{font-size:13px;font-weight:800;margin-bottom:6px}
.rb-manual-rows{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.rb-manual-row{display:flex;justify-content:space-between;align-items:center;gap:10px}
.rb-manual-ticker{font-size:12px;font-weight:700}
.rb-manual-input{width:120px;padding:8px 10px;border:1px solid var(--bdr);border-radius:8px;font-size:16px}
.rb-manual-summary{margin-top:8px;font-size:12px;color:var(--tx2);font-family:var(--mo)}
.review-data-meta{font-size:11px;color:var(--mt);margin-bottom:8px}
#pg-rb{padding-bottom:88px}
@media (max-width:420px){
  .rb-group-row{flex-direction:column}
  .rb-group-row.compact{grid-template-columns:1fr}
  .rb-group-actions{grid-column:auto;grid-row:auto;justify-content:flex-start}
  .rb-metrics{align-items:flex-start;width:100%}
  .rb-actions .btn{flex:1}
  .rb-editor-head{grid-template-columns:1fr}
  .rb-target-inline{min-width:0}
  .rb-map-row{padding:8px}
  .rb-map-select{flex:0 0 132px;max-width:132px}
  .rb-map-target{flex:0 0 auto}
  .rb-map-target-input{width:88px}
  .rb-editor-page-footer{grid-template-columns:1fr}
  .rb-map-meta-row{align-items:flex-end}
  .rb-metric-strip{grid-template-columns:1fr}
  .rb-table-head,.rb-table-row{grid-template-columns:minmax(110px,1.4fr) .9fr .9fr .9fr auto;font-size:11px}
  .rb-detail-grid{grid-template-columns:1fr}
  .rb-trigger-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .rb-trigger-grid-2{grid-template-columns:1fr}
  .rb-rail-asset-popup .ms{max-width:100%;padding:10px 10px calc(12px + env(safe-area-inset-bottom))}
  .rb-rail-asset-grid4{grid-template-columns:repeat(4,minmax(0,1fr))}
  .rb-rail-asset-grid3{grid-template-columns:repeat(3,minmax(0,1fr))}
  .rb-rail-asset-cell{padding:6px 4px}
  .rb-rail-asset-cell span{font-size:9px}
  .rb-rail-asset-cell strong{font-size:11px}
  .rb-rail-immediate-cols{grid-template-columns:1fr}
  .rb-rail-row-pct{font-size:15px}
}
@media (max-width:640px){
  input,
  select,
  textarea,
  .rb-input,
  .rb-map-select{
    font-size:16px;
  }
}
