/* ============================================================
   Polyspect — shared design tokens & components
   Direction B "Modern fintech". Dark-first. Plain CSS, no build.
   ============================================================ */

:root{
  /* ---- color: surfaces ---- */
  --bg:#0b1120;
  --bg-grad-1:#1b3158;          /* radial top-right */
  --bg-grad-2:#15233f;          /* radial top-left  */
  --panel:#111c33;
  --panel-2:#16233d;
  --panel-3:#0f1a30;            /* header strips */
  --line:#223150;
  --line-2:#2c3f63;
  --line-soft:rgba(34,49,80,.45);

  /* ---- color: text ---- */
  --tx:#e8eef6;
  --mut:#94a3b8;
  --dim:#64748b;
  --dimmer:#475569;

  /* ---- color: signal ---- */
  --green:#34d399;   --green-d:#10b981;
  --sky:#38bdf8;     --sky-d:#0ea5e9;
  --red:#f87171;     --red-d:#ef4444;
  --amber:#fbbf24;
  --violet:#a78bfa;

  --green-bg:rgba(52,211,153,.12);
  --green-bd:rgba(52,211,153,.26);
  --sky-bg:rgba(56,189,248,.12);
  --sky-bd:rgba(56,189,248,.24);
  --red-bg:rgba(248,113,113,.12);
  --red-bd:rgba(248,113,113,.26);

  /* ---- type ---- */
  --mono:ui-monospace,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;
  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  /* ---- radius ---- */
  --r-sm:7px; --r-md:11px; --r-lg:15px; --r-xl:18px; --r-pill:999px;

  /* ---- elevation ---- */
  --sh-1:0 1px 0 rgba(255,255,255,.02) inset, 0 10px 30px -18px rgba(0,0,0,.7);
  --sh-2:0 24px 60px -30px rgba(0,0,0,.8);
  --sh-pop:0 20px 44px rgba(0,0,0,.6);

  /* ---- layout ---- */
  --maxw:1440px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;color:var(--tx);font-family:var(--sans);font-size:14px;line-height:1.4;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background:
    radial-gradient(1100px 700px at 88% -8%, var(--bg-grad-1) 0%, rgba(27,49,88,0) 58%),
    radial-gradient(900px 600px at 10% 0%, var(--bg-grad-2) 0%, rgba(21,35,63,0) 60%),
    var(--bg);
  background-attachment:fixed;
}
a{color:var(--sky);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- utilities ---- */
.mono{font-family:var(--mono)}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;text-align:right}
.pos{color:var(--green)} .neg{color:var(--red)} .sky{color:var(--sky)}
.mut{color:var(--mut)} .dim{color:var(--dim)} .amber{color:var(--amber)}
.tl{text-align:left} .tr{text-align:right} .tc{text-align:center}
.nowrap{white-space:nowrap}

/* ============================================================
   TOP BAR
   ============================================================ */
.top{position:sticky;top:0;z-index:60;display:flex;align-items:center;gap:28px;height:62px;padding:0 30px;
  background:rgba(11,17,32,.72);backdrop-filter:blur(18px) saturate(1.3);
  -webkit-backdrop-filter:blur(18px) saturate(1.3);border-bottom:1px solid rgba(34,49,80,.7)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand .mark{flex:none;display:block}
.logo{font-weight:700;font-size:19px;letter-spacing:-.4px;color:var(--tx);text-decoration:none;display:flex;flex-direction:column}
.logo:hover{text-decoration:none}
.logo b{color:var(--green)}
.logo .row1{line-height:1}
.logo .tag{font-size:9.5px;font-weight:600;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;margin-top:3px}
.nav{display:flex;gap:6px}
.nav a{padding:9px 16px;border-radius:var(--r-md);color:var(--mut);font-size:14px;font-weight:500}
.nav a:hover{color:var(--tx);text-decoration:none}
.nav a.on{color:var(--tx);background:var(--sky-bg);box-shadow:inset 0 0 0 1px var(--sky-bd)}
.spacer{flex:1}
.auth{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--mut)}
.auth .u{color:var(--tx);font-weight:600}
.pill-live{display:inline-flex;align-items:center;gap:7px;background:var(--green-bg);border:1px solid var(--green-bd);
  color:var(--green);padding:6px 11px;border-radius:var(--r-pill);font-size:12px;font-weight:600}
.pill-live.off{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}
.pill-live .dot{width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 9px currentColor}

/* ============================================================
   PAGE SCAFFOLD
   ============================================================ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:30px 30px 80px}
.head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;flex-wrap:wrap}
.head h1{margin:0;font-size:30px;font-weight:700;letter-spacing:-.8px}
.head .sub{color:var(--mut);font-size:14.5px;margin-top:7px;max-width:620px;text-wrap:pretty}
.head .sub b{color:var(--green);font-weight:600}
.head .now{font-family:var(--mono);font-size:12px;color:var(--dim);text-align:right;line-height:1.7}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--dim);margin-bottom:14px}
.crumbs a{color:var(--mut)} .crumbs .sep{color:var(--dimmer)}

.section{margin-top:30px}
.section-h{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}
.section-h h2{margin:0;font-size:17px;font-weight:600;letter-spacing:-.3px}
.section-h .meta{font-size:12.5px;color:var(--dim);font-family:var(--mono)}

/* ============================================================
   STAT CARDS
   ============================================================ */
.stats{display:grid;gap:14px}
.stats.c7{grid-template-columns:repeat(7,1fr)}
.stats.c6{grid-template-columns:repeat(6,1fr)}
.stats.c2{grid-template-columns:1fr 1fr}
.stats.c1{grid-template-columns:1fr}
.stats.c5{grid-template-columns:repeat(5,1fr)}
.stats.c4{grid-template-columns:repeat(4,1fr)}
.stats.c3{grid-template-columns:repeat(3,1fr)}
.stat{background:linear-gradient(180deg,rgba(22,35,61,.7),rgba(17,28,51,.7));border:1px solid var(--line);
  border-radius:var(--r-lg);padding:16px 17px 17px;box-shadow:var(--sh-1)}
.stat .stop{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:11px}
.stat .slabel{font-size:11.5px;color:var(--mut);font-weight:600}
.stat .svalue{font-family:var(--mono);font-size:26px;font-weight:600;letter-spacing:-.8px;line-height:1.05}
.stat .ssub{font-size:11.5px;color:var(--dim);margin-top:6px}
.stat.tight{padding:13px 14px 14px}
.stat.tight .svalue{font-size:21px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;gap:8px;justify-content:center;cursor:pointer;
  font-family:var(--sans);font-size:13.5px;font-weight:600;padding:10px 16px;border-radius:var(--r-md);
  border:1px solid var(--line-2);background:var(--panel-2);color:var(--tx);white-space:nowrap;transition:.12s}
.btn:hover{text-decoration:none;border-color:var(--sky-bd);background:#1a2942}
.btn-primary{background:var(--green);border-color:var(--green);color:#04130c}
.btn-primary:hover{background:#42e0a6;border-color:#42e0a6}
.btn-sky{background:var(--sky);border-color:var(--sky);color:#04131f}
.btn-sky:hover{background:#5cc8fb;border-color:#5cc8fb}
.btn-danger{background:var(--red-bg);border-color:var(--red-bd);color:var(--red)}
.btn-danger:hover{background:rgba(248,113,113,.2);border-color:var(--red)}
.btn-ghost{background:transparent}
.btn-sm{padding:6px 11px;font-size:12.5px;border-radius:var(--r-sm)}
.btn-lg{padding:13px 22px;font-size:15px}
.btn[disabled]{opacity:.5;cursor:not-allowed}

/* ============================================================
   FILTER TOOLBAR
   ============================================================ */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.search{position:relative;flex:1;min-width:240px;max-width:400px}
.search input{width:100%;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-md);
  color:var(--tx);padding:12px 14px 12px 40px;font-size:14px;font-family:var(--sans)}
.search input::placeholder{color:var(--dimmer)}
.search:before{content:"\2315";position:absolute;left:13px;top:11px;color:var(--dim);font-size:17px}
.fcell{display:flex;flex-direction:column;justify-content:center;background:var(--panel);border:1px solid var(--line-2);
  border-radius:var(--r-md);padding:6px 14px;height:46px}
.fcell label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);font-weight:700}
.fcell input{width:62px;background:transparent;border:0;color:var(--tx);font-family:var(--mono);font-size:14px;padding:0}
.fcell input:focus{outline:none}
select.view,select.sel{height:46px;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-md);
  color:var(--tx);font-size:14px;padding:0 14px;min-width:200px;font-family:var(--sans);cursor:pointer}
.segs{display:flex;gap:4px;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-md);padding:4px}
.seg{font-size:12.5px;padding:8px 13px;border-radius:var(--r-sm);color:var(--mut);cursor:pointer;font-weight:500}
.seg:hover{color:var(--tx)}
.seg.on{background:var(--green);color:#04130c;font-weight:700}
.ml-auto{margin-left:auto}

/* ============================================================
   TABLES
   ============================================================ */
.tablebox{background:linear-gradient(180deg,rgba(17,28,51,.6),rgba(14,23,42,.6));border:1px solid var(--line);
  border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-2)}
.tablebox.flat{box-shadow:none}
table.tbl{width:100%;border-collapse:collapse}
/* 2026-06-11: thead is NO LONGER position:sticky. The sticky+top:62px
   header inside `.tablebox{overflow-x:auto}` (a scroll container) is
   dead per spec (sticks to the box, not the viewport) and actively
   glitches in Safari — the header strip detaches and paints OVER body
   rows, hiding the row beneath it ("trader hidden under a panel").
   Same class of bug as the 2026-06-08 invisible-tbody incident. Plain
   static header everywhere. */
.tbl thead th{background:var(--panel-3);text-align:right;font-size:11px;
  text-transform:uppercase;letter-spacing:.06em;color:var(--dim);font-weight:700;padding:13px 16px;
  border-bottom:1px solid var(--line-2);white-space:nowrap}
.tbl thead th.l{text-align:left}
.tbl tbody td{padding:0 16px;height:56px;border-bottom:1px solid var(--line-soft);font-size:14px;vertical-align:middle}
.tbl.dense tbody td{height:46px;font-size:13px}
.tbl tbody tr:last-child td{border-bottom:0}
.tbl tbody tr:hover{background:rgba(56,189,248,.045)}
.tbl .c-rank{color:var(--dimmer);font-family:var(--mono);font-size:13px;width:34px}
.tbl-foot{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;color:var(--dim);
  font-size:12.5px;border-top:1px solid var(--line)}

/* wallet cell */
.wallet{display:flex;align-items:center;gap:12px}
.ident{border-radius:9px;background:linear-gradient(135deg,#0e1830,#0a1322);flex:none}
.wmeta{display:flex;flex-direction:column;gap:2px;line-height:1.2;min-width:0}
.wname{font-size:14.5px;font-weight:600;white-space:nowrap}
.wname.anon{color:var(--dim);font-weight:500;font-style:italic}
.waddr{font-size:12px;color:var(--dim);font-family:var(--mono)}

/* Leaderboard density (2026-06-13): the traders table had ~13 columns and
   overflowed 1440px → horizontal scroll. Tighten cell padding and shrink
   the Wallet column (compact identicon + ellipsised name) so it fits on a
   normal screen. Scoped to `.lb` so other tables keep their roomier look. */
.tbl.lb tbody td{padding:0 9px}
.tbl.lb thead th{padding:13px 9px}
.tbl.lb .wallet{gap:9px}
/* Cap the NAME element (not the td — table-layout:auto ignores max-width
   on cells) so a long pseudonym ellipsises instead of widening the column. */
.tbl.lb .wname{font-size:13.5px;max-width:130px;overflow:hidden;text-overflow:ellipsis}
.tbl.lb .waddr{font-size:11px}

/* score bar */
.scorewrap{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.sval{font-family:var(--mono);font-size:16px;font-weight:600}
.sbar{height:6px;background:#1a2942;border-radius:4px;overflow:hidden}
.sbar i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--sky),var(--green))}

/* activity strip */
.acts{display:inline-flex;gap:3px;align-items:center}
.acts i{width:7px;height:7px;border-radius:50%;display:block}

/* ============================================================
   BADGES / PILLS
   ============================================================ */
.pill{display:inline-block;font-family:var(--mono);font-weight:600;font-size:13px;padding:4px 9px;border-radius:var(--r-sm);white-space:nowrap}
.pill.pos{color:var(--green);background:var(--green-bg)}
.pill.neg{color:var(--red);background:var(--red-bg)}
.pill.neu{color:var(--mut);background:rgba(148,163,184,.1)}
.pat{display:inline-block;font-size:11.5px;font-weight:600;padding:5px 10px;border-radius:var(--r-sm);color:var(--pc,var(--sky));
  background:color-mix(in srgb,var(--pc,var(--sky)) 13%,transparent);
  border:1px solid color-mix(in srgb,var(--pc,var(--sky)) 26%,transparent);white-space:nowrap}
.mir{font-size:15px;margin:0 1px}
.mdash{color:var(--dimmer)}
.tag-badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;padding:4px 9px;border-radius:var(--r-pill)}
.tag-live{background:var(--red-bg);border:1px solid var(--red-bd);color:var(--red)}
.tag-shadow{background:rgba(167,139,250,.12);border:1px solid rgba(167,139,250,.28);color:var(--violet)}
.tag-on{background:var(--green-bg);border:1px solid var(--green-bd);color:var(--green)}
.tag-off{background:rgba(148,163,184,.1);border:1px solid var(--line-2);color:var(--mut)}
.tag-paused{background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.28);color:var(--amber)}
.statusdot{width:8px;height:8px;border-radius:50%;display:inline-block}
.statusdot.on{background:var(--green);box-shadow:0 0 8px var(--green)}
.statusdot.off{background:var(--red)}

/* copy dropdown (native <details>) */
.copy{position:relative;display:inline-block}
.copy>summary{list-style:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--sky);
  padding:8px 12px;border:1px solid var(--line-2);border-radius:var(--r-md);background:var(--panel-2);white-space:nowrap}
.copy>summary::-webkit-details-marker{display:none}
.copy[open]>summary{background:var(--sky-bg);border-color:var(--sky)}
.copy .menu{position:absolute;right:0;top:calc(100% + 6px);width:236px;background:#13203a;border:1px solid var(--line-2);
  border-radius:var(--r-md);box-shadow:var(--sh-pop);z-index:80;padding:6px;text-align:left}
.copy .menu.left{right:auto;left:0}
/* Flip the dropdown upward when the row sits near the bottom of its
   .tablebox — overflow-x:auto on the box clips anything that extends
   past it, so a down-opening menu on the last rows was invisible.
   Class applied by the global toggler in base.html. */
.copy .menu.up{top:auto;bottom:calc(100% + 6px)}
.menu-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--dim);padding:8px 10px 6px;font-weight:700}
.menu a{display:flex;justify-content:space-between;align-items:center;padding:9px 10px;border-radius:var(--r-sm);color:var(--tx);
  font-size:13.5px;cursor:pointer}
.menu a:hover{background:var(--sky-bg);text-decoration:none}
.menu a .cnt{font-family:var(--mono);font-size:11px;color:var(--mut);background:#1a2942;border-radius:5px;padding:2px 7px}
.menu a.new{color:var(--green);border-top:1px solid var(--line);margin-top:4px;padding-top:11px}

/* ============================================================
   PANELS / CARDS / KEY-VALUE
   ============================================================ */
.panel{background:linear-gradient(180deg,rgba(17,28,51,.62),rgba(14,23,42,.62));border:1px solid var(--line);
  border-radius:var(--r-xl);box-shadow:var(--sh-1)}
.panel-h{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 18px;border-bottom:1px solid var(--line)}
.panel-h h3{margin:0;font-size:15px;font-weight:600}
.panel-b{padding:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.kv{display:grid;grid-template-columns:1fr auto;gap:10px 16px;font-size:13.5px}
.kv dt{color:var(--mut)} .kv dd{margin:0;font-family:var(--mono);text-align:right;font-variant-numeric:tabular-nums}

/* ============================================================
   FORMS
   ============================================================ */
.form{display:flex;flex-direction:column;gap:18px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;font-weight:600;color:var(--tx)}
.field .lblrow{display:flex;justify-content:space-between;align-items:baseline}
.field .opt{font-size:11.5px;color:var(--dim);font-weight:500}
.field input[type=text],.field input[type=password],.field input[type=email],.field input[type=number],.field textarea,.field select{
  width:100%;background:var(--panel);border:1px solid var(--line-2);border-radius:var(--r-md);color:var(--tx);
  padding:12px 14px;font-size:14px;font-family:var(--sans)}
.field input.mono{font-family:var(--mono)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px var(--sky-bg)}
.field .hint{font-size:12px;color:var(--dim);line-height:1.5}
.inwrap{position:relative;display:flex;align-items:center}
.inwrap .pre{position:absolute;left:13px;color:var(--mut);font-family:var(--mono);font-size:14px;pointer-events:none}
.inwrap .suf{position:absolute;right:13px;color:var(--dim);font-family:var(--mono);font-size:12.5px;pointer-events:none}
.inwrap input{padding-left:28px!important}
.check{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--mut);cursor:pointer}
.check input{width:18px;height:18px;margin-top:1px;accent-color:var(--green)}

/* ============================================================
   CHARTS
   ============================================================ */
.chart{width:100%;display:block}
.chart .grid line{stroke:var(--line);stroke-width:1}
.chart .axis{fill:var(--dim);font-family:var(--mono);font-size:10px}
.chart-legend{display:flex;gap:18px;font-size:12px;color:var(--mut);margin-top:10px}
.chart-legend i{width:10px;height:10px;border-radius:2px;display:inline-block;margin-right:6px;vertical-align:middle}

/* ============================================================
   AUDIT LOG
   ============================================================ */
.audit{display:flex;flex-direction:column}
.audit .row{display:grid;grid-template-columns:150px 180px 1fr;gap:14px;padding:11px 18px;border-bottom:1px solid var(--line-soft);
  font-size:13px;align-items:center}
.audit .row:last-child{border-bottom:0}
.audit .ts{font-family:var(--mono);font-size:12px;color:var(--dim)}
.audit .ev{font-family:var(--mono);font-size:12px;font-weight:600}
.audit .ev.good{color:var(--green)} .audit .ev.warn{color:var(--amber)} .audit .ev.bad{color:var(--red)} .audit .ev.info{color:var(--sky)}
.audit .desc{color:var(--mut)}

/* ============================================================
   MOBILE: bottom nav + accordion (used by *_mobile.html)
   ============================================================ */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:70;display:flex;height:60px;
  background:rgba(11,17,32,.9);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-top:1px solid var(--line)}
.bottomnav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  color:var(--dim);font-size:10.5px;font-weight:600}
.bottomnav a:hover{text-decoration:none}
.bottomnav a.on{color:var(--green)}
.bottomnav a svg{width:21px;height:21px;display:block}
.acc{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--panel)}
.acc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;font-weight:600;font-size:14px}
.acc>summary::-webkit-details-marker{display:none}
.acc>summary:after{content:"\25be";color:var(--dim);transition:.2s}
.acc[open]>summary:after{transform:rotate(180deg)}
.acc .acc-b{padding:0 16px 16px;border-top:1px solid var(--line)}

/* mobile tabs (radio-less, using :target-free simple scroll) */
.mtabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}
.mtabs a{flex:none;padding:8px 14px;border-radius:var(--r-pill);font-size:13px;font-weight:600;
  background:var(--panel);border:1px solid var(--line-2);color:var(--mut)}
.mtabs a.on{background:var(--green);border-color:var(--green);color:#04130c}
.mtabs a:hover{text-decoration:none}

/* ============================================================
   MOBILE: phone frame, header, list cards
   ============================================================ */
.phone{max-width:412px;margin:0 auto;min-height:100vh;position:relative;padding-bottom:78px;
  border-left:1px solid var(--line);border-right:1px solid var(--line);background:
   radial-gradient(700px 400px at 90% -6%, var(--bg-grad-1) 0%, rgba(27,49,88,0) 60%), var(--bg)}
@media(max-width:440px){.phone{border:0}}
.topm{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:12px;height:56px;padding:0 16px;
  background:rgba(11,17,32,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.topm .back{font-size:20px;color:var(--mut);text-decoration:none;margin-left:-4px}
.topm .mtitle{font-size:16px;font-weight:700;letter-spacing:-.3px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topm .brand-m{display:flex;align-items:center;gap:8px;font-weight:700;font-size:17px;letter-spacing:-.3px;flex:1}
.topm .brand-m b{color:var(--green)}
.topm .ham{width:38px;height:38px;border:1px solid var(--line-2);border-radius:10px;background:var(--panel);
  display:flex;align-items:center;justify-content:center;color:var(--mut);font-size:16px;cursor:pointer}
.mwrap{padding:18px 16px 24px}
.mhead h1{font-size:23px;font-weight:700;letter-spacing:-.5px;margin:0 0 6px}
.mhead .sub{font-size:13px;color:var(--mut);text-wrap:pretty;margin-bottom:18px}
.bottomnav.m{left:50%;transform:translateX(-50%);width:100%;max-width:412px}

/* mobile list card (collapsed table row) */
.lcardm{background:linear-gradient(180deg,rgba(22,35,61,.7),rgba(17,28,51,.7));border:1px solid var(--line);
  border-radius:var(--r-lg);padding:14px;margin-bottom:10px}
.lcardm .lc-top{display:flex;align-items:center;gap:11px}
.lc-rank{font-family:var(--mono);font-size:12px;color:var(--dimmer);width:20px;flex:none}
.lc-main{flex:1;min-width:0}
.lc-name{font-size:14.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lc-addr{font-family:var(--mono);font-size:11px;color:var(--dim)}
.lc-right{text-align:right;flex:none}
.lc-stats{display:flex;gap:6px;margin-top:11px;flex-wrap:wrap}
.lc-stat{flex:1;min-width:64px;background:var(--panel);border:1px solid var(--line-soft);border-radius:8px;padding:7px 9px}
.lc-stat .k{font-size:9.5px;color:var(--dim);text-transform:uppercase;letter-spacing:.04em;font-weight:700}
.lc-stat .v{font-family:var(--mono);font-size:13px;font-weight:600;margin-top:2px}
.dgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ============================================================
   RESPONSIVE COLLAPSE — desktop → tablet → mobile
   Designed at 1440px desktop / 390px phone; these media queries
   bridge the gap so the same templates work on narrow viewports
   without serving separate Jinja files.
   ============================================================ */
@media(max-width:1100px){
  .wrap{padding:24px 16px 64px}
  .stats.c7{grid-template-columns:repeat(4,1fr)}
  .stats.c6{grid-template-columns:repeat(3,1fr)}
  .stats.c5{grid-template-columns:repeat(3,1fr)}
  .stats.c4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .head h1{font-size:24px}
}
@media(max-width:760px){
  .top{padding:0 14px;gap:14px}
  .top .nav a{padding:8px 11px;font-size:13px}
  .top .auth .u{display:none}
  .wrap{padding:18px 12px 88px}
  .head h1{font-size:21px}
  .head .now{display:none}
  .stats.c7,.stats.c6,.stats.c5,.stats.c4,.stats.c3{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .toolbar{gap:8px}
  .toolbar .search{min-width:0}
  .toolbar .segs{display:none}
  /* Big tables: horizontal scroll inside tablebox so the design's
     dense columns survive on narrow screens. */
  .tablebox{overflow-x:auto}
  table.tbl{min-width:760px}
  .audit .row{grid-template-columns:90px 1fr;gap:8px}
  .audit .row .ev{grid-column:2}
}
@media(max-width:480px){
  .stats.c7,.stats.c6,.stats.c5,.stats.c4,.stats.c3{grid-template-columns:1fr 1fr}
  .stat .svalue{font-size:21px}
  .panel-b{padding:14px}
  .head{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   STAT CARD POLISH — 2026-06-05
   Original 26px svalue overflowed cramped 6-up grids at 1280px and lower
   (wallet detail page especially). Scale the value font down when the
   grid is denser than 4 cards, and ensure consistent left alignment.
   ============================================================ */
.stats.c7 .stat .svalue,
.stats.c6 .stat .svalue,
.stats.c5 .stat .svalue{font-size:21px;letter-spacing:-.4px}
.stats.c7 .stat{padding:14px 13px 15px}
.stats.c7 .stat .svalue{font-size:19px;letter-spacing:-.3px}
.stat .svalue{text-align:left;overflow-wrap:break-word;word-break:keep-all}
.stat .slabel{display:block}
/* Inline split rows used by live_overview wallet cards — left-align numbers
   to match the label above them. Default .num text-align:right pushed values
   to the right edge and misaligned with their labels. */
.wsplit .num{text-align:left}

/* ============================================================
   TABLE OVERFLOW FIX — 2026-06-05
   .tablebox had `overflow:hidden` to give it nice rounded corners,
   but if a table outgrew the viewport (extra columns, long
   strategy names) the row content was clipped invisibly. Force
   horizontal scroll on overflow at every viewport, not just mobile.
   ============================================================ */
.tablebox{overflow-x:auto;overflow-y:visible}
table.tbl{min-width:0}
@media(max-width:760px){table.tbl{min-width:760px}}
/* Sanity row visibility — make sure tbody rows are never hidden by
   weird inherited styling (Dark Reader / forced-colors / etc.). */
.tbl tbody tr{display:table-row;visibility:visible}
.tbl tbody td{color:var(--tx)}
