/* ============================================================
   Cherum Partners — cabinet.css  (extracted 1:1 from host <style>)
   Vanilla, CSP-clean. Tokens on app --cw-* / OKLCH (dark+light).
   Pairs with: partners/cabinet.js (controller) + widget/widget.css,
   widget/cherum-widget.js (window.CherumWidget), widget/playground.js
   (window.CherumSnippet). Self-host fonts: Inter Tight / Instrument
   Serif / JetBrains Mono — system fallback until /fonts is wired.

   USAGE (if splitting in repo): remove the inline <style> from the
   host HTML and add <link rel="stylesheet" href="cabinet.css"> in
   <head> after widget.css. Host already ships CSS inline, so use
   ONE or the OTHER — never both (avoids double-load).

   This file is a mirror of the host's inline <style>; regenerate it
   whenever the host styles change so the two never drift.
   ============================================================ */
:root{
  --r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-2xl:26px;
  --ff:"Inter Tight",ui-sans-serif,system-ui,-apple-system,"Segoe UI",sans-serif; /* @kind font */
  --serif:"Instrument Serif","Iowan Old Style",Georgia,serif; /* @kind font */
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace; /* @kind font */
  --ease:cubic-bezier(.2,.8,.2,1); /* @kind other */
}
[data-theme="dark"]{
  --bg-0:oklch(0.17 0.010 310);--bg-1:oklch(0.205 0.012 310);--bg-2:oklch(0.25 0.014 310);--bg-3:oklch(0.29 0.016 310);
  --line:oklch(0.32 0.018 310);--line-2:oklch(0.38 0.022 310);
  --text-1:oklch(0.93 0.008 310);--text-2:oklch(0.78 0.012 310);--text-3:oklch(0.63 0.016 310);
  --accent:oklch(0.74 0.14 305);--accent-hi:oklch(0.82 0.14 305);--accent-ink:#18121F;
  --good:oklch(0.74 0.11 162);--good-hi:oklch(0.82 0.12 162);--good-bg:oklch(0.30 0.05 162);
  --warn:oklch(0.80 0.12 78);--warn-hi:oklch(0.86 0.12 82);--warn-bg:oklch(0.32 0.05 70);
  --info:oklch(0.72 0.08 235);
  --card-grad:linear-gradient(180deg,color-mix(in oklab,var(--bg-1) 94%,transparent),color-mix(in oklab,var(--bg-0) 82%,transparent));
  --hairline:color-mix(in oklab,var(--text-1) 11%,transparent);
  --mesh-a:oklch(0.31 0.10 305 / 0.40);--mesh-b:oklch(0.27 0.085 342 / 0.30);
  color-scheme:dark;
}
[data-theme="light"]{
  --bg-0:oklch(0.975 0.004 310);--bg-1:oklch(0.99 0.003 310);--bg-2:oklch(0.945 0.006 310);--bg-3:oklch(0.915 0.008 310);
  --line:oklch(0.88 0.010 310);--line-2:oklch(0.82 0.012 310);
  --text-1:oklch(0.22 0.012 310);--text-2:oklch(0.40 0.014 310);--text-3:oklch(0.52 0.016 310);
  --accent:oklch(0.52 0.16 305);--accent-hi:oklch(0.44 0.16 305);--accent-ink:#fff;
  --good:oklch(0.52 0.13 162);--good-hi:oklch(0.44 0.13 162);--good-bg:oklch(0.93 0.04 162);
  --warn:oklch(0.62 0.13 70);--warn-hi:oklch(0.52 0.13 70);--warn-bg:oklch(0.94 0.05 80);
  --info:oklch(0.50 0.09 235);
  --card-grad:linear-gradient(180deg,#fff,color-mix(in oklab,var(--bg-1) 90%,transparent));
  --hairline:color-mix(in oklab,var(--text-1) 9%,transparent);
  --mesh-a:oklch(0.82 0.07 305 / 0.40);--mesh-b:oklch(0.87 0.055 342 / 0.32);
  color-scheme:light;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff);background:var(--bg-0);color:var(--text-1);font-size:15px;line-height:1.55;
  -webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono)}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-0.015em;line-height:1.08}
.caps{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}
.tnum{font-variant-numeric:tabular-nums}

/* ============ buttons ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;font-weight:600;font-size:14px;
  padding:11px 16px;cursor:pointer;border:1px solid transparent;transition:.15s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:linear-gradient(180deg,var(--accent-hi),var(--accent));color:var(--accent-ink);border-color:color-mix(in oklab,var(--accent) 60%,white)}
.btn-primary:hover{filter:brightness(1.05)}
.btn-primary[disabled]{background:var(--bg-2);color:var(--text-3);border-color:var(--line);cursor:not-allowed;filter:none}
.btn-ghost{background:var(--bg-1);color:var(--text-1);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--bg-2)}
.btn-sm{padding:8px 12px;font-size:13px;border-radius:9px}
.btn-lg{padding:14px 20px;font-size:15px}

/* pills */
.pill{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:600;
  font-family:var(--mono);letter-spacing:.02em;white-space:nowrap}
.pill-good{background:color-mix(in oklab,var(--good) 14%,transparent);color:var(--good-hi);border:1px solid color-mix(in oklab,var(--good) 36%,transparent)}
.pill-warn{background:color-mix(in oklab,var(--warn) 15%,transparent);color:var(--warn-hi);border:1px solid color-mix(in oklab,var(--warn) 38%,transparent)}
.pill-neutral{background:var(--bg-2);color:var(--text-2);border:1px solid var(--line-2)}
.pill-accent{background:color-mix(in oklab,var(--accent) 14%,transparent);color:var(--accent-hi);border:1px solid color-mix(in oklab,var(--accent) 34%,transparent)}
.dot{width:6px;height:6px;border-radius:999px;background:currentColor;flex:none}

/* card */
.card{background-image:var(--card-grad);border:1px solid var(--hairline);border-radius:var(--r-lg);box-shadow:0 1px 2px rgba(0,0,0,.05)}

/* ============ logo ============ */
.logo-a{display:inline-flex;color:var(--text-1)}

/* ============ AUTH / LOGIN ============ */
.auth{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;overflow:hidden}
.auth::before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(52% 44% at 16% -6%,var(--mesh-a),transparent 70%),radial-gradient(46% 42% at 100% 4%,var(--mesh-b),transparent 72%)}
.auth-card{width:100%;max-width:440px;padding:34px 32px 28px;text-align:center;position:relative}
.auth-logo{position:relative;width:62px;height:62px;border-radius:18px;background:var(--bg-1);border:1px solid var(--hairline);
  display:grid;place-items:center;margin:0 auto 20px;box-shadow:0 12px 34px color-mix(in oklab,var(--accent) 22%,transparent)}
.auth-logo::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(120% 120% at 50% 0%,color-mix(in oklab,var(--accent) 15%,transparent),transparent 68%)}
.auth-logo.warn{box-shadow:0 12px 34px color-mix(in oklab,var(--warn) 24%,transparent)}
.auth-logo.warn::after{background:radial-gradient(120% 120% at 50% 0%,color-mix(in oklab,var(--warn) 16%,transparent),transparent 68%)}
.auth-logo svg,.onb-logo svg{position:relative;z-index:1}
.auth h1{font-size:26px;letter-spacing:-0.02em;margin-bottom:9px}
.auth p.sub{font-size:14.5px;color:var(--text-2);line-height:1.55;margin-bottom:22px;max-width:34em;margin-left:auto;margin-right:auto}
.auth-hint{display:flex;align-items:flex-start;gap:9px;text-align:left;padding:11px 13px;border-radius:11px;margin-bottom:20px;
  background:color-mix(in oklab,var(--accent) 8%,transparent);border:1px solid color-mix(in oklab,var(--accent) 26%,transparent);
  font-size:12.5px;color:var(--text-2);line-height:1.45}
.auth-hint svg{color:var(--accent-hi);flex:none;margin-top:1px}
.auth-hint b{color:var(--text-1);font-weight:600}
.wallet-opts{display:flex;flex-direction:column;gap:10px}
.wallet-opt{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:12px;border:1px solid var(--line-2);
  background:var(--bg-1);cursor:pointer;transition:.15s;text-align:left}
.wallet-opt:hover{border-color:color-mix(in oklab,var(--accent) 45%,transparent);background:var(--bg-2)}
.wallet-opt .ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex:none;font-size:16px}
.wallet-opt .nm{font-weight:600;font-size:14px}
.wallet-opt .ds{font-size:11.5px;color:var(--text-3)}
.wallet-opt .go{margin-left:auto;color:var(--text-3)}
.auth-foot{margin-top:22px;font-size:12px;color:var(--text-3)}
.auth-foot a{color:var(--accent-hi)}
.sign-anim{display:flex;flex-direction:column;align-items:center;gap:16px;padding:14px 0 6px}
.sign-spin{width:40px;height:40px;border-radius:999px;border:3px solid color-mix(in oklab,var(--accent) 26%,transparent);border-top-color:var(--accent);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.auth-error{display:flex;align-items:flex-start;gap:9px;text-align:left;padding:11px 13px;border-radius:11px;margin-bottom:18px;
  background:color-mix(in oklab,var(--warn) 12%,transparent);border:1px solid color-mix(in oklab,var(--warn) 38%,transparent);
  font-size:12.5px;color:var(--text-2)}
.auth-error svg{color:var(--warn-hi);flex:none;margin-top:1px}

/* ============ CABINET SHELL ============ */
.cabinet{display:none;min-height:100vh;container-type:inline-size}
body.authed .auth{display:none}
body.authed .cabinet{display:block}
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{border-right:1px solid var(--line);background:color-mix(in oklab,var(--bg-1) 50%,transparent);
  display:flex;flex-direction:column;padding:20px 16px;position:sticky;top:0;height:100vh}
.side-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 22px;font-weight:600;letter-spacing:-0.028em;font-size:16px}
.side-brand .mk{width:28px;height:28px;display:grid;place-items:center;flex:none}
.side-brand .tag{font-family:var(--mono);font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:var(--accent-hi);
  border:1px solid color-mix(in oklab,var(--accent) 34%,transparent);border-radius:999px;padding:2px 8px;margin-left:auto}
.nav{display:flex;flex-direction:column;gap:3px;flex:1}
.nav-i{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:10px;color:var(--text-2);font-weight:500;font-size:14px;cursor:pointer;transition:.13s;position:relative}
.nav-i:hover{color:var(--text-1);background:var(--bg-2)}
.nav-i.active{color:var(--text-1);background:var(--bg-2)}
.nav-i.active::before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--accent)}
.nav-i svg{flex:none;color:currentColor}
.nav-i .soon{margin-left:auto;font-family:var(--mono);font-size:8.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-3);border:1px solid var(--line);border-radius:999px;padding:1px 6px}
.nav-sep{height:1px;background:var(--line);margin:12px 4px}
.side-foot{display:flex;flex-direction:column;gap:10px}
.wallet-chip{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:11px;border:1px solid var(--line);background:var(--bg-1)}
.wallet-chip .av{width:26px;height:26px;border-radius:999px;background:conic-gradient(from 200deg,var(--accent),var(--info),var(--good),var(--accent));flex:none}
.wallet-chip .wm{flex:1;min-width:0}
.wallet-chip .wa{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wallet-chip .wl{font-size:10.5px;color:var(--text-3)}
.wallet-chip .dis{cursor:pointer;color:var(--text-3);width:26px;height:26px;border-radius:7px;display:grid;place-items:center;border:none;background:none}
.wallet-chip .dis:hover{color:var(--text-1);background:var(--bg-2)}
.side-row{display:flex;align-items:center;gap:8px}
.iconbtn{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:var(--bg-1);color:var(--text-2);display:grid;place-items:center;cursor:pointer}
.iconbtn:hover{color:var(--text-1)}

/* main */
.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;padding:22px 32px 0}
.topbar .ttl{flex:1;min-width:0}
.topbar h1{font-size:24px;letter-spacing:-0.02em;line-height:1.1}
.topbar .crumb{font-size:12.5px;color:var(--text-3);margin-bottom:3px}
.content{padding:24px 32px 56px;display:flex;flex-direction:column;gap:20px}
.mobile-topbar{display:none}

/* period selector */
.period{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.period button{font-size:12.5px;font-weight:600;padding:6px 11px;border-radius:6px;color:var(--text-3);border:none;background:none;cursor:pointer}
.period button.on{background:var(--accent);color:var(--accent-ink)}

/* segmented (money view switch) */
.seg{display:inline-flex;background:var(--bg-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.seg button{font-size:12.5px;font-weight:600;padding:6px 12px;border-radius:6px;color:var(--text-3);border:none;background:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
.seg button.on{background:var(--bg-0);color:var(--text-1);box-shadow:0 1px 2px rgba(0,0,0,.12)}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat{padding:16px 17px}
.stat .k{font-size:11.5px;color:var(--text-3);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.stat .v{font-size:24px;font-weight:600;letter-spacing:-0.02em}
.stat .d{font-size:11.5px;color:var(--text-3);margin-top:4px}
.stat .d b{color:var(--good-hi);font-weight:600}

/* section heading */
.sec-h{display:flex;align-items:center;gap:14px;margin-bottom:2px}
.sec-h h2{font-size:16px;font-weight:600;letter-spacing:-0.01em}
.sec-h .sh-r{margin-left:auto;display:flex;align-items:center;gap:10px}
.sec-sub{font-size:12.5px;color:var(--text-3);margin-top:2px}

/* ====== MONEY HONESTY BLOCK ====== */
.money-wrap{display:flex;flex-direction:column;gap:14px}
/* shared money card pieces */
.mcard{padding:20px 21px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.mcard .mc-top{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.mcard .mc-ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}
.mcard .mc-h{font-size:13.5px;font-weight:600}
.mcard .mc-s{font-size:11px;color:var(--text-3);margin-top:1px}
.mcard .mc-big{font-size:34px;font-weight:600;letter-spacing:-0.025em;line-height:1}
.mcard .mc-cur{font-size:16px;color:var(--text-3);font-weight:500;margin-left:3px}
.mcard .mc-meta{font-size:12px;color:var(--text-3);margin-top:7px;line-height:1.5}
.mc-evm .mc-ico{background:color-mix(in oklab,var(--good) 18%,transparent);color:var(--good-hi)}
.mc-evm{border-color:color-mix(in oklab,var(--good) 26%,transparent)}
.mc-evm::after{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,var(--good),transparent)}
.mc-nonevm .mc-ico{background:color-mix(in oklab,var(--warn) 18%,transparent);color:var(--warn-hi)}
.mc-nonevm{border-color:color-mix(in oklab,var(--warn) 30%,transparent)}
.mc-nonevm::after{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:linear-gradient(90deg,var(--warn),transparent)}
.mc-foot{margin-top:auto;padding-top:14px}
.mc-links{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.mc-txlink{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--text-3);padding:6px 9px;border-radius:8px;background:var(--bg-1);border:1px solid var(--hairline)}
.mc-txlink .mono{color:var(--text-2)}
.mc-txlink .amt{margin-left:auto;color:var(--good-hi);font-family:var(--mono);font-weight:600}
.mc-txlink svg{color:var(--text-3)}
.mc-txlink:hover{border-color:var(--line-2)}
/* threshold progress */
.thresh{margin-top:14px}
.thresh-bar{height:7px;border-radius:99px;background:var(--bg-3);overflow:hidden;margin:8px 0 6px}
.thresh-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--warn),var(--warn-hi))}
.thresh-row{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--text-3)}

/* variation: two cards */
.money-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
/* variation: ledger */
.money-ledger .ldg{display:grid;grid-template-columns:1fr 1px 1fr;gap:0;padding:0;overflow:hidden}
.ldg-col{padding:20px 22px}
.ldg-div{background:var(--line)}
.ldg-col .lc-top{display:flex;align-items:center;gap:9px;margin-bottom:12px}
.ldg-col .lc-ico{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:none}
.ldg-evm .lc-ico{background:color-mix(in oklab,var(--good) 18%,transparent);color:var(--good-hi)}
.ldg-nonevm .lc-ico{background:color-mix(in oklab,var(--warn) 18%,transparent);color:var(--warn-hi)}
.ldg-col .lc-h{font-size:12.5px;font-weight:600}.ldg-col .lc-s{font-size:10.5px;color:var(--text-3)}
.ldg-col .lc-big{font-size:28px;font-weight:600;letter-spacing:-0.02em}
.ldg-col .lc-rows{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.ldg-lrow{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-3)}
.ldg-lrow b{color:var(--text-1);font-weight:600;font-family:var(--mono)}
.ldg-col .lc-cta{margin-top:14px}
/* variation: tabs */
.money-tabs .mt-head{display:flex;gap:4px;padding:5px;background:var(--bg-2);border-radius:11px;border:1px solid var(--line);margin-bottom:0;width:fit-content}
.mt-tab{display:flex;align-items:center;gap:8px;padding:9px 15px;border-radius:8px;font-size:13px;font-weight:600;color:var(--text-3);cursor:pointer;border:none;background:none}
.mt-tab.on{color:var(--text-1)}
.mt-tab.on.evm{background:color-mix(in oklab,var(--good) 16%,transparent)}
.mt-tab.on.nonevm{background:color-mix(in oklab,var(--warn) 16%,transparent)}
.mt-tab .tdot{width:7px;height:7px;border-radius:99px}
.mt-body{margin-top:14px}
/* auto money view: two cards on desktop, tabs on mobile (production default, no toggle) */
.money-auto .money-tabs{display:none}
/* honesty legend (desktop only — tabs carry their own labels on mobile) */
.money-legend{display:flex;gap:14px}
.money-legend .lg{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}
.money-legend .lgd{width:7px;height:7px;border-radius:99px}

/* chart */
.chart-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:16px}
.spark-wrap{padding:18px 20px}
.spark-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:14px}
.spark-big{font-size:26px;font-weight:600;letter-spacing:-0.02em}
.spark{position:relative}
.chart{width:100%;height:auto;display:block;touch-action:none}
.ch-grid{stroke:var(--hairline);stroke-width:1}
.ch-ylab{font-family:var(--mono);font-size:9px;fill:var(--text-3);opacity:.85}
.ch-xlab{font-family:var(--mono);font-size:9px;fill:var(--text-3)}
.ch-guide{stroke:var(--accent);stroke-width:1;stroke-dasharray:3 3;opacity:0;transition:opacity .12s}
.ch-guide.on{opacity:.55}
.ch-dot{fill:var(--accent-hi);stroke:var(--bg-1);stroke-width:2;opacity:0;transition:opacity .12s}
.ch-dot.on{opacity:1}
.ch-tip{position:absolute;top:0;transform:translateX(-50%);pointer-events:none;opacity:0;transition:opacity .12s;
  background:var(--bg-0);border:1px solid var(--line-2);border-radius:8px;padding:5px 9px;white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.28);z-index:2}
.ch-tip.on{opacity:1}
.ch-tip b{font-family:var(--mono);font-size:12px;font-weight:600;color:var(--text-1);display:block}
.ch-tip i{font-style:normal;font-size:10px;color:var(--text-3)}
.break{padding:18px 20px}
.brk-row{display:flex;align-items:center;gap:10px;padding:7px 0}
.brk-row .bk-disc{width:20px;height:20px;border-radius:999px;display:grid;place-items:center;font-family:var(--mono);font-size:8px;font-weight:700;color:#fff;flex:none}
.brk-row .bk-n{font-size:12.5px;font-weight:500;width:64px}
.brk-row .bk-track{flex:1;height:6px;border-radius:99px;background:var(--bg-3);overflow:hidden}
.brk-row .bk-fill{height:100%;border-radius:99px}
.brk-row .bk-v{font-family:var(--mono);font-size:11.5px;color:var(--text-2);width:58px;text-align:right;font-weight:600}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);font-weight:500;padding:10px 12px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px;border-bottom:1px solid var(--hairline);color:var(--text-2)}
.tbl tr:last-child td{border-bottom:none}
.tbl td b{color:var(--text-1);font-weight:600}
.tbl .r-amt{font-family:var(--mono);font-weight:600;color:var(--text-1)}
.tbl .ex{color:var(--text-3);display:inline-flex;align-items:center;gap:5px}
.tbl .ex:hover{color:var(--accent-hi)}
.route-cell{display:flex;align-items:center;gap:7px}
.mini-disc{width:18px;height:18px;border-radius:999px;display:grid;place-items:center;font-family:var(--mono);font-size:8px;font-weight:700;color:#fff;flex:none}
.fan-arrow{color:var(--text-3);font-size:11px}

/* payouts hero */
.payout-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:16px}
.payout-main{padding:22px 24px}
.payout-avail{font-size:13px;color:var(--text-3);margin-bottom:6px}
.payout-big{font-size:40px;font-weight:600;letter-spacing:-0.025em;line-height:1}
.payout-big .cur{font-size:18px;color:var(--text-3);font-weight:500}
.payout-sub{font-size:12.5px;color:var(--text-3);margin-top:8px;line-height:1.5}
.payout-side{padding:20px 22px;display:flex;flex-direction:column;gap:12px}
.po-line{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text-2)}
.po-line b{font-family:var(--mono);font-weight:600;color:var(--text-1)}
.po-dest{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:11px;background:var(--bg-1);border:1px solid var(--hairline);font-size:12.5px}
.po-dest .mono{color:var(--text-2)}

/* non-EVM rate setting (Model B) */
.rate-card{padding:18px 20px;margin-bottom:14px;display:flex;flex-direction:column;gap:14px}
.rate-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.rate-h-l{flex:1;min-width:0}
.rate-desc{font-size:12px;color:var(--text-3);line-height:1.55;margin-top:6px;max-width:54ch}
.rate-desc b{color:var(--text-2);font-weight:600}
.rate-current{text-align:right;flex:none}
.rate-pct{font-size:26px;font-weight:600;letter-spacing:-0.02em;color:var(--warn-hi)}
.rate-edit{display:flex;gap:10px;align-items:flex-end}
.rate-edit .field{flex:1;margin:0}
.rate-edit .input:disabled{opacity:.5;cursor:not-allowed}
.rate-edit .btn{flex:none}
.rate-note{display:flex;gap:8px;align-items:flex-start;font-size:12px;line-height:1.5;color:var(--text-3);padding:10px 12px;border-radius:10px;background:var(--bg-1);border:1px solid var(--hairline)}
.rate-note b{color:var(--text-2);font-weight:600}
.rate-note svg{flex:none;margin-top:1px;color:var(--text-3)}
.rate-note[hidden]{display:none}
.rate-note.ok{background:color-mix(in oklab,var(--good) 12%,transparent);border-color:color-mix(in oklab,var(--good) 30%,transparent);color:var(--good-hi)}
.rate-note.ok b,.rate-note.ok svg{color:var(--good-hi)}
.rate-note.bad{background:color-mix(in oklab,var(--warn) 12%,transparent);border-color:color-mix(in oklab,var(--warn) 32%,transparent);color:var(--warn-hi)}
.rate-note.bad b,.rate-note.bad svg{color:var(--warn-hi)}
@container (max-width:620px){.rate-head{flex-direction:column;gap:8px}.rate-current{text-align:left}.rate-edit{flex-direction:column;align-items:stretch}.rate-edit .btn{width:100%}}

/* integration */
.intg-grid{display:grid;grid-template-columns:1fr 420px;gap:24px;align-items:start}
.intg-config{display:flex;flex-direction:column;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:7px}
.field .hint{font-size:11.5px;color:var(--text-3);font-weight:400}
.input{width:100%;padding:11px 13px;border-radius:10px;border:1px solid var(--line-2);background:var(--bg-1);color:var(--text-1);font:inherit;font-size:14px;outline:none}
.input:focus{border-color:var(--accent)}
.input.ro{background:var(--bg-2);color:var(--text-2);font-family:var(--mono);font-size:13px;display:flex;align-items:center;gap:8px}
.input-row{display:flex;gap:10px}
.codeblock{background:var(--bg-0);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden}
.codetabs{display:flex;gap:2px;padding:8px 8px 0;border-bottom:1px solid var(--line)}
.codetab{font-family:var(--mono);font-size:11.5px;padding:7px 12px;border-radius:8px 8px 0 0;color:var(--text-3);cursor:pointer}
.codetab.active{color:var(--text-1);background:var(--bg-2)}
.codeblock pre{font-family:var(--mono);font-size:12px;line-height:1.7;padding:15px 16px;overflow-x:auto;color:var(--text-2);white-space:pre}
.codeblock pre .k{color:var(--accent-hi)}.codeblock pre .s{color:var(--good-hi)}.codeblock pre .c{color:var(--text-3)}
.copybtn{float:right;font-family:var(--mono);font-size:10.5px;color:var(--text-3);border:1px solid var(--line-2);border-radius:7px;padding:3px 9px;cursor:pointer;background:var(--bg-1)}
.copybtn:hover{color:var(--text-1)}
.intg-preview{position:sticky;top:24px;display:flex;flex-direction:column;gap:12px}
.intg-stage{display:flex;justify-content:center;padding:22px;border-radius:var(--r-xl);border:1px solid var(--hairline);
  background:repeating-linear-gradient(45deg,transparent,transparent 11px,color-mix(in oklab,var(--text-1) 3%,transparent) 11px,color-mix(in oklab,var(--text-1) 3%,transparent) 12px)}

/* onboarding */
.onb{max-width:760px;margin:0 auto;text-align:center;padding:20px 0 10px}
.onb-logo{position:relative;width:66px;height:66px;border-radius:19px;background:var(--bg-1);border:1px solid var(--hairline);display:grid;place-items:center;margin:0 auto 18px;box-shadow:0 12px 34px color-mix(in oklab,var(--accent) 20%,transparent)}
.onb-logo::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:radial-gradient(120% 120% at 50% 0%,color-mix(in oklab,var(--accent) 14%,transparent),transparent 68%)}
.onb h1{font-size:30px;letter-spacing:-0.02em;margin-bottom:10px}
.onb p.lead{font-size:16px;color:var(--text-2);max-width:36em;margin:0 auto 26px;line-height:1.6}
.onb-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;text-align:left;margin-bottom:24px}
.onb-step{padding:20px}
.onb-step .n{font-family:var(--mono);font-size:11px;color:var(--accent-hi);margin-bottom:12px}
.onb-step h3{font-size:15px;font-weight:600;margin-bottom:6px}
.onb-step p{font-size:13px;color:var(--text-3);line-height:1.5}
.onb-cta{display:flex;gap:11px;justify-content:center;flex-wrap:wrap}

/* banners */
.banner{display:flex;align-items:flex-start;gap:11px;padding:13px 15px;border-radius:12px;font-size:13px;line-height:1.5}
.banner svg{flex:none;margin-top:1px}
.banner.info{background:color-mix(in oklab,var(--info) 11%,transparent);border:1px solid color-mix(in oklab,var(--info) 32%,transparent);color:var(--text-2)}
.banner.info svg{color:var(--info)}
.banner.warn{background:color-mix(in oklab,var(--warn) 12%,transparent);border:1px solid color-mix(in oklab,var(--warn) 36%,transparent);color:var(--text-2)}
.banner.warn svg{color:var(--warn-hi)}
.banner b{color:var(--text-1);font-weight:600}

/* skeleton/empty for screens */
.screen{display:none;flex-direction:column;gap:20px}
.screen.active{display:flex}

/* ====== unified chain/coin icon ====== */
.coin{display:inline-grid;place-items:center;border-radius:999px;font-family:var(--mono);font-weight:700;letter-spacing:-0.02em;
  flex:none;line-height:1;box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.16),0 1px 1px rgba(0,0,0,.10)}
[data-theme="light"] .coin{box-shadow:inset 0 0 0 1.5px rgba(0,0,0,.10)}

/* ====== skeleton / empty / error ====== */
.skel{display:block;background:linear-gradient(90deg,var(--bg-2) 25%,var(--bg-3) 37%,var(--bg-2) 63%);background-size:400% 100%;animation:shimmer 1.4s ease infinite;border-radius:6px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}
.sk-col{display:flex;flex-direction:column;gap:10px}
.sk-banner{height:44px;border-radius:12px}
.empty-card{padding:48px 32px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:5px}
.empty-ico{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;margin-bottom:8px;background:var(--bg-2);color:var(--text-3)}
.empty-ico.warn{background:color-mix(in oklab,var(--warn) 16%,transparent);color:var(--warn-hi)}
.empty-card h2{font-size:18px;font-weight:600;letter-spacing:-0.01em}
.empty-card p{font-size:13.5px;color:var(--text-3);max-width:34em;line-height:1.55;margin-bottom:8px}
@media(prefers-reduced-motion:reduce){.skel{animation:none}}

/* ====== tables scroll ====== */
.tbl-wrap{width:100%;overflow-x:auto}

/* ====== activity feed ====== */
.act-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.act-filter button{display:inline-flex;align-items:center;gap:7px}
.act-filter .afn{font-family:var(--mono);font-size:10px;padding:1px 6px;border-radius:999px;background:var(--bg-0);color:var(--text-3);border:1px solid var(--hairline)}
.act-filter button.on .afn{background:color-mix(in oklab,var(--accent) 24%,transparent);color:var(--accent-hi);border-color:transparent}
.act-legend{display:flex;gap:14px}
.act-legend .lg{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}
.act-legend .lgd{width:7px;height:7px;border-radius:99px}
.act-list{padding:4px 6px}
.act-day{padding:2px 0 6px}
.act-dh{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 7px;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}
.act-dt{color:var(--text-2);font-weight:600}
.act-row{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:10px;transition:background .12s}
.act-row:hover{background:var(--bg-2)}
.act-meta{flex:1;min-width:0}
.act-t{font-size:13.5px;color:var(--text-2);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.act-t b{color:var(--text-1);font-weight:600}
.act-s{font-size:11.5px;color:var(--text-3);margin-top:2px}
.act-s .ex{color:var(--text-3)}
.act-s .ex:hover{color:var(--accent-hi)}
.act-amt{font-family:var(--mono);font-size:14px;font-weight:600;white-space:nowrap;flex:none}
.act-amt.good{color:var(--good-hi)}
.act-amt.warn{color:var(--warn-hi)}

/* ============ DEMO DOCK ============ */
.demo-dock{position:fixed;right:18px;bottom:18px;z-index:200;font-family:var(--ff)}
.demo-toggle{width:46px;height:46px;border-radius:13px;background:var(--bg-2);border:1px solid var(--line-2);color:var(--text-1);
  display:grid;place-items:center;cursor:pointer;box-shadow:0 8px 24px rgba(0,0,0,.3)}
.demo-panel{position:absolute;right:0;bottom:56px;width:268px;padding:14px;border-radius:14px;background:var(--bg-1);
  border:1px solid var(--line-2);box-shadow:0 18px 50px rgba(0,0,0,.4);display:none}
.demo-dock.open .demo-panel{display:block}
.demo-h{font-family:var(--mono);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3);margin:2px 0 9px}
.demo-h:not(:first-child){margin-top:14px;padding-top:12px;border-top:1px solid var(--hairline)}
.demo-grid{display:flex;flex-wrap:wrap;gap:6px}
.demo-grid button{font-size:11.5px;font-weight:600;padding:6px 9px;border-radius:8px;border:1px solid var(--line-2);background:var(--bg-2);color:var(--text-2);cursor:pointer}
.demo-grid button:hover{color:var(--text-1)}
.demo-grid button.on{background:var(--accent);color:var(--accent-ink);border-color:transparent}
.demo-note{font-size:10.5px;color:var(--text-3);margin-top:10px;line-height:1.4}

/* ============ container-query responsive (drives real mobile AND the phone-frame preview) ============ */
@container (max-width:820px){
  .shell{grid-template-columns:1fr}
  .side{position:fixed;bottom:0;left:0;right:0;top:auto;height:auto;flex-direction:row;align-items:center;gap:4px;
    padding:8px 10px;border-right:none;border-top:1px solid var(--line);background:color-mix(in oklab,var(--bg-1) 96%,transparent);
    backdrop-filter:blur(12px);z-index:80}
  .side-brand,.nav-sep,.side-foot,.nav .soon{display:none}
  .nav{flex-direction:row;justify-content:space-around;gap:2px;width:100%}
  .nav-i{flex-direction:column;gap:3px;font-size:9.5px;padding:6px 4px;flex:1;text-align:center}
  .nav-i.active::before{display:none}
  .nav-i.active{background:none;color:var(--accent-hi)}
  .nav-i svg{width:20px;height:20px}
  .main{padding-bottom:64px}
  .mobile-topbar{display:flex;align-items:center;gap:12px;padding:14px 18px 0}
  .topbar{padding:14px 18px 0}.topbar h1{font-size:20px}
  .content{padding:18px 18px 40px;gap:16px}
  .stats{grid-template-columns:1fr 1fr}
  .money-2{grid-template-columns:1fr}
  .money-ledger .ldg{grid-template-columns:1fr;}
  .money-auto .money-2{display:none}
  .money-auto .money-tabs{display:block}
  .sec-h .money-legend{display:none}
  .ldg-div{height:1px}
  .chart-grid{grid-template-columns:1fr}
  .payout-hero{grid-template-columns:1fr}
  .intg-grid{grid-template-columns:1fr}
  .intg-preview{position:static}
  .onb-steps{grid-template-columns:1fr}
  .tbl .hide-sm{display:none}
  .topbar{flex-wrap:wrap}
  #topbar-right{width:100%}
  .act-legend{display:none}
  .act-head{gap:10px}
  .act-amt{font-size:13px}
  .act-row{gap:10px;padding:10px 8px}
  .empty-card{padding:36px 20px}
  .act-list,.tbl-wrap{-webkit-overflow-scrolling:touch}
}

/* phone frame (demo aid) */
body.mobileframe{background:var(--bg-0);padding:0}
body.mobileframe .cabinet{max-width:402px;margin:24px auto;min-height:840px;height:840px;border:10px solid #0c0a11;border-radius:42px;
  overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5);position:relative}
body.mobileframe .cabinet .shell{min-height:820px}
body.mobileframe .side{position:absolute}
body.mobileframe .main{height:820px;overflow-y:auto}
body.mobileframe .demo-dock{position:fixed}
