/* ============================================================
   BondDesk — soft, friendly, rounded. Light + dark themes.
   All color via CSS variables; toggling [data-theme] swaps the set.
   ============================================================ */
:root, html[data-theme="light"]{
  --bg:#f5f7fc; --bg2:#eef1fa; --panel:#ffffff; --panel2:#f4f6fc;
  --line:#e6e9f4; --line2:#dfe3f0;
  --txt:#1b2236; --txt2:#39425c; --muted:#5f6a7d; --faint:#677183;
  --accent:#5563f0; --accent-ink:#3f4cd6; --accent-soft:rgba(85,99,240,.10);
  --teal:#0fb5a2; --teal-soft:rgba(15,181,162,.12); --ibadge-fg:#0a6f64;
  --up:#12a05a; --down:#e0524d; --warn:#c98a16;
  --shadow:0 1px 2px rgba(28,40,80,.05), 0 6px 20px rgba(28,40,80,.06);
  --shadow-sm:0 1px 2px rgba(28,40,80,.06);
  --shadow-hover:0 4px 10px rgba(28,40,80,.08), 0 14px 32px rgba(28,40,80,.12);
}
html[data-theme="dark"]{
  --bg:#0e1220; --bg2:#10152480; --panel:#161c2e; --panel2:#1b2236;
  --line:#283150; --line2:#313c5e;
  --txt:#e8ecf8; --txt2:#c2c9de; --muted:#97a0b8; --faint:#9aa2bd;
  --accent:#8893ff; --accent-ink:#a3abff; --accent-soft:rgba(136,147,255,.14);
  --teal:#34d6c3; --teal-soft:rgba(52,214,195,.16); --ibadge-fg:#34d6c3;
  --up:#34d399; --down:#f4807a; --warn:#e0b15a;
  --shadow:0 1px 2px rgba(0,0,0,.35), 0 8px 26px rgba(0,0,0,.40);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-hover:0 6px 14px rgba(0,0,0,.4), 0 18px 40px rgba(0,0,0,.55);
}
:root{ --r:18px; --r-sm:12px; --r-pill:999px; --wrap:1180px;
       --fs:15px; --mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,monospace; }

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--txt);
  font:var(--fs)/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;transition:background .25s,color .25s}
a{color:var(--accent-ink);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{color:var(--txt);line-height:1.2;margin:0}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 22px}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.small{font-size:13px} .micro{font-size:12px} .mono{font-family:var(--mono)}
.r{text-align:right} .strong{font-weight:700}
code{font-family:var(--mono);background:var(--panel2);padding:1px 6px;border-radius:6px}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--panel) 88%,transparent);
  backdrop-filter:saturate(1.4) blur(10px);border-bottom:1px solid var(--line)}
.bar{display:flex;align-items:center;gap:18px;min-height:66px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:11px;color:var(--txt)}
.brand:hover{text-decoration:none}
.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--teal));color:#fff;font-size:16px;
  box-shadow:var(--shadow-sm)}
.brand-text{display:flex;flex-direction:column;line-height:1.12}
.brand-name{font-weight:800;font-size:18px;letter-spacing:-.01em}
.brand-accent{color:var(--accent)}
.brand-tag{font-size:11px;color:var(--muted);font-weight:500}
.menu{display:flex;gap:6px;flex:1;flex-wrap:wrap}
.pill{padding:8px 15px;border-radius:var(--r-pill);color:var(--txt2);font-weight:600;font-size:14px;
  border:1px solid var(--line2);background:var(--panel);transition:background .15s,color .15s,border-color .15s}
.pill:hover{background:var(--panel2);text-decoration:none;color:var(--txt);border-color:var(--accent)}
.pill.on{background:var(--accent-soft);color:var(--accent-ink);border-color:var(--accent)}
.bar-right{display:flex;align-items:center;gap:10px}
.search input{background:var(--panel2);border:1px solid var(--line2);color:var(--txt);
  padding:9px 14px;border-radius:var(--r-pill);width:190px;font-size:14px;transition:border-color .15s,box-shadow .15s}
.search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.search{position:relative}
.search-results{position:absolute;top:46px;right:0;width:340px;max-width:82vw;background:var(--panel);
  border:1px solid var(--line2);border-radius:var(--r-sm);box-shadow:var(--shadow-hover);overflow:hidden;z-index:40}
.sr-item{display:flex;align-items:center;gap:10px;padding:9px 13px;border-bottom:1px solid var(--line);color:var(--txt)}
.sr-item:last-child{border-bottom:0}
.sr-item:hover,.sr-item.on{background:var(--panel2);text-decoration:none}
.sr-kind{flex-shrink:0;font-size:10px;font-weight:800;padding:2px 6px;border-radius:5px;letter-spacing:.03em}
.sr-issuer{background:var(--accent-soft);color:var(--accent-ink)}
.sr-treasury{background:var(--teal-soft);color:var(--ibadge-fg)}
.sr-main{display:flex;flex-direction:column;min-width:0;font-size:13.5px;font-weight:600}
.sr-sub{font-size:11.5px;color:var(--muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sector-filter{margin-bottom:18px}
.cc-count{font-size:11px;opacity:.65;font-weight:700;margin-left:3px}
.theme-btn{width:40px;height:40px;border-radius:12px;border:1px solid var(--line2);
  background:var(--panel2);color:var(--txt2);font-size:17px;cursor:pointer;transition:all .15s}
.theme-btn:hover{color:var(--accent-ink);border-color:var(--accent)}

/* ---------- generic layout ---------- */
main{padding:30px 0 60px}
.page-head{margin:4px 0 22px}
.page-head.narrow,.narrow{max-width:720px}
.page-head h1{font-size:28px;letter-spacing:-.02em;margin-bottom:6px}
.cols{display:grid;grid-template-columns:1.35fr 1fr;gap:20px;align-items:start}
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.link{font-weight:600;font-size:13.5px;white-space:nowrap}

/* ---------- card ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:20px 22px;box-shadow:var(--shadow);margin-bottom:20px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.card-head h2{font-size:16px;letter-spacing:-.01em}
.card h2{font-size:18px}
.prose .card{margin-bottom:18px} .prose .card h2{margin-bottom:10px}
.prose ul,.prose ol{margin:8px 0 0;padding-left:20px} .prose li{margin:5px 0}
.prose p{color:var(--txt2);margin:10px 0 0}

/* ---------- hero ---------- */
.hero{background:
   radial-gradient(120% 140% at 0% 0%,var(--accent-soft),transparent 55%),
   radial-gradient(120% 140% at 100% 0%,var(--teal-soft),transparent 55%),
   var(--panel);
  border:1px solid var(--line);border-radius:24px;padding:42px 40px;margin-bottom:22px;box-shadow:var(--shadow)}
.hero-text{max-width:680px}
.hero h1{font-size:38px;letter-spacing:-.03em;line-height:1.08}
.lede{font-size:17px;color:var(--txt2);margin:14px 0 22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:var(--r-pill);
  background:var(--accent);color:#fff;font-weight:700;font-size:15px;border:1px solid transparent;
  cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .15s,background .15s}
.btn:hover{text-decoration:none;transform:translateY(-1px);box-shadow:var(--shadow-hover);background:var(--accent-ink)}
.btn.ghost{background:var(--panel);color:var(--accent-ink);border-color:var(--line2)}
.btn.ghost:hover{background:var(--panel2)}
.btn.small{padding:8px 16px;font-size:14px}

/* ---------- stat row / tiles ---------- */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:15px 17px;box-shadow:var(--shadow-sm)}
.stat-k{font-size:12px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:5px}
.stat-v{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-top:3px}
.stat-sub{font-size:11.5px;color:var(--faint);margin-top:1px}
.metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}
.metric-grid .stat{background:var(--panel2);box-shadow:none}
.metric-grid .stat-v{font-size:19px}

/* ---------- charts ---------- */
.chart-wrap{width:100%;overflow:hidden;border-radius:var(--r-sm)}
.chart-wrap.big{padding:6px 0}
.chart{width:100%;height:auto;display:block}
.chart .grid{stroke:var(--line);stroke-width:1}
.chart .ylab,.chart .xlab{fill:var(--muted);font-size:11px;font-family:inherit}
.chart .area{fill:var(--accent-soft)}
.chart .line{stroke-width:2.4;stroke-linejoin:round;stroke-linecap:round}
.chart .line-par{stroke:var(--accent)}
.chart .line-zero{stroke:var(--teal);stroke-dasharray:5 4;stroke-width:2}
.chart .dot{fill:var(--accent);stroke:var(--panel);stroke-width:1.5}
.legend{display:flex;gap:18px;flex-wrap:wrap;font-size:12.5px;color:var(--muted);margin-top:10px}
.legend .sw{display:inline-block;width:14px;height:4px;border-radius:2px;vertical-align:middle;margin-right:6px}
.sw-par{background:var(--accent)} .sw-zero{background:var(--teal)}
.hist-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.hist-block .hist-label{font-size:13px;font-weight:700;margin-bottom:4px}
.hist-grid .chart{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--panel2)}

/* ---------- type tiles / highlights ---------- */
.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.type-tile{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r-sm);padding:13px 15px;
  display:block;border-left:4px solid var(--tp,var(--accent));transition:transform .12s,box-shadow .15s,border-color .15s}
.type-tile:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow)}
.type-row{display:flex;align-items:center;gap:9px}
.type-ico{display:grid;place-items:center;width:26px;height:26px;border-radius:8px;background:var(--tp,var(--accent));color:#fff}
.type-ico .tg{width:15px;height:15px}
.type-name{font-weight:800;font-size:15px}
.type-n{margin-left:auto;font-weight:800;font-size:18px;color:var(--txt)}
.type-desc{font-size:12px;color:var(--muted);margin:7px 0 0;line-height:1.4}
.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.hl{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r-sm);padding:15px;display:block;transition:transform .12s,box-shadow .15s}
.hl:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow)}
.hl-top{display:flex;align-items:center;gap:8px}
.hl-label{font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:700}
.hl-ytw{margin:10px 0 8px;display:flex;align-items:baseline;gap:7px}
.hl-ytw-v{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--accent-ink)}
.hl-ytw-k{font-size:11.5px;color:var(--muted);font-weight:600}
.hl-meta{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* ---------- type colour pills (the primary anchor; solid colour = identity) ---------- */
/* white text on every signature colour, all verified >=4.5:1 in light & dark */
.tpill{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:800;letter-spacing:.02em;
  padding:3px 9px 3px 7px;border-radius:var(--r-pill);background:var(--tp,#475569);color:#fff;white-space:nowrap}
.tpill .tg{width:13px;height:13px;flex-shrink:0}
.tpill-l{line-height:1}
.t-bill{--tp:#3b6fd4} .t-note{--tp:#2a55c8} .t-bond{--tp:#1b3a8f}
.t-tips{--tp:#0d7d72} .t-frn{--tp:#0e6f86} .t-call{--tp:#b42318} .t-corp{--tp:#475569}
.t-muni{--tp:#157a3d} .t-agency{--tp:#6d44aa}

/* ---------- rating badges (green -> red across the IG / junk line) ---------- */
.rbadge{display:inline-flex;align-items:center;font-size:11px;font-weight:800;letter-spacing:.02em;
  padding:3px 9px;border-radius:var(--r-pill);background:var(--rb,#475569);color:#fff;white-space:nowrap}
.rbadge.big{font-size:13px;padding:6px 14px}
.rbadge[data-tip]{cursor:help}
.r-govt{--rb:#157a3d} .r-aa{--rb:#157a3d} .r-a{--rb:#0f766e} .r-bbb{--rb:#8f5b0c}
.r-bb{--rb:#c2410c} .r-b{--rb:#9a3412} .r-ccc{--rb:#b42318}

/* "indicative" provenance label (kept high-contrast) */
.ibadge{display:inline-flex;align-items:center;font-size:10.5px;font-weight:800;text-transform:uppercase;
  letter-spacing:.05em;padding:3px 8px;border-radius:6px;background:var(--teal-soft);
  color:var(--ibadge-fg);cursor:help}
.tag-fetched,.tag-computed{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  padding:2px 8px;border-radius:6px}
.tag-fetched{background:var(--accent-soft);color:var(--accent-ink)}
.tag-computed{background:var(--teal-soft);color:var(--ibadge-fg)}

/* ---------- info tooltip ---------- */
.info{display:inline-grid;place-items:center;width:15px;height:15px;border-radius:50%;
  background:var(--line2);color:var(--muted);font-size:10px;font-weight:800;font-style:normal;cursor:help;
  vertical-align:middle}
.info:hover,.info:focus{background:var(--accent);color:#fff;outline:none}
[data-tip]{position:relative}
[data-tip]:hover::after,[data-tip]:focus::after,.info:hover::after,.info:focus::after{
  content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);
  width:max-content;max-width:280px;background:var(--txt);color:var(--bg);padding:9px 12px;border-radius:10px;
  font-size:12px;font-weight:500;line-height:1.45;letter-spacing:0;text-transform:none;z-index:50;
  box-shadow:var(--shadow-hover);pointer-events:none;white-space:normal;text-align:left}
[data-tip]:hover::before,.info:hover::before,.info:focus::before{
  content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--txt);z-index:50}

/* ---------- filters ---------- */
.filters{margin-bottom:16px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}
.chip-row{display:flex;gap:7px;flex-wrap:wrap}
.chip{padding:7px 15px;border-radius:var(--r-pill);background:var(--panel);border:1px solid var(--line2);
  color:var(--txt2);font-weight:600;font-size:13.5px;transition:all .14s}
.chip:hover{text-decoration:none;border-color:var(--accent);color:var(--accent-ink)}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.filter-controls{display:flex;gap:12px;flex-wrap:wrap}
.sel{display:flex;flex-direction:column;font-size:11px;color:var(--muted);font-weight:600;gap:3px}
.sel select{background:var(--panel);border:1px solid var(--line2);color:var(--txt);padding:8px 12px;
  border-radius:10px;font-size:14px;font-weight:600;cursor:pointer}
.sel select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}

/* ---------- tables ---------- */
.table-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.table-card.flush{box-shadow:none;border-radius:var(--r-sm)}
table.grid{width:100%;border-collapse:collapse;font-size:14px}
table.grid thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;
  color:var(--muted);font-weight:700;padding:13px 16px;background:var(--panel2);border-bottom:1px solid var(--line);white-space:nowrap}
table.grid th.r{text-align:right}
table.grid tbody td{padding:12px 16px;border-bottom:1px solid var(--line)}
table.grid.compact tbody td,table.grid.compact thead th{padding:9px 14px}
table.grid tbody tr:last-child td{border-bottom:0}
.row{cursor:pointer;transition:background .12s}
.row:hover{background:var(--panel2)}
.row:focus{outline:2px solid var(--accent);outline-offset:-2px}
.th-sub{font-weight:600;text-transform:none;letter-spacing:0;color:var(--faint);font-size:10px}
.cusip-link{font-weight:700;color:var(--txt)}
.cusip-sub{font-family:var(--mono);font-size:11px;color:var(--faint)}
.empty{text-align:center;color:var(--muted);padding:40px}
table.grid tfoot td{padding:12px 16px;border-top:2px solid var(--line2)}
.note{margin-top:12px}

/* key/value table (terms) */
table.kv{width:100%;border-collapse:collapse;font-size:14px}
table.kv td{padding:10px 2px;border-bottom:1px solid var(--line);vertical-align:top}
table.kv tr:last-child td{border-bottom:0}
table.kv td:first-child{color:var(--muted);font-weight:600;width:46%}
table.kv td:last-child{text-align:right;font-weight:600}

/* ---------- detail head ---------- */
.crumbs{font-size:13px;color:var(--muted);margin-bottom:14px}
.crumbs a{font-weight:600} .crumbs span{margin:0 7px;color:var(--faint)}
.detail-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:22px 24px;
  box-shadow:var(--shadow);margin-bottom:20px;flex-wrap:wrap}
.dh-badges{display:flex;gap:7px;margin-bottom:10px;flex-wrap:wrap}
.detail-head h1{font-size:25px;letter-spacing:-.02em}
.detail-head .mono{font-size:13px;margin-top:5px}
.price-hero{text-align:right;background:var(--accent-soft);border-radius:var(--r-sm);padding:14px 20px;min-width:200px}
.ph-k{font-size:12px;color:var(--accent-ink);font-weight:700}
.ph-v{font-size:32px;font-weight:800;letter-spacing:-.02em;color:var(--txt);line-height:1.1}
.ph-sub{font-size:12px;color:var(--muted);margin-top:2px}
.callout{background:var(--teal-soft);border:1px solid color-mix(in srgb,var(--teal) 35%,transparent);
  border-radius:var(--r-sm);padding:13px 16px;color:var(--txt2);font-size:13.5px;margin:0 0 18px}
.prose .callout{margin:12px 0 0}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);background:var(--panel);margin-top:30px;padding:26px 0 40px}
footer p{margin:0 0 8px;max-width:880px}
.disclaim{color:var(--txt2);font-size:13.5px}
.disclaim.card{margin-top:6px;border-left:4px solid var(--accent)}

/* ---------- not found ---------- */
.notfound{text-align:center;padding:70px 0}
.nf-mark{font-size:46px;color:var(--accent);opacity:.5}
.notfound h1{font-size:30px;margin:10px 0 6px}
.notfound .hero-cta{justify-content:center;margin-top:20px}

/* ---------- category header (no-logo issuer header) ---------- */
.cat-head{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:22px 24px;box-shadow:var(--shadow);margin-bottom:18px}
.cat-id{display:flex;gap:16px;align-items:flex-start}
.cat-seal{flex-shrink:0}
.cat-seal svg{width:54px;height:54px}
.seal-ring{stroke:var(--accent);stroke-width:2;fill:var(--accent-soft)}
.seal-star{fill:var(--accent)}
.cat-head h1{font-size:25px;letter-spacing:-.02em}
.cat-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:10px}
.ichip{font-size:12px;font-weight:600;color:var(--txt2);background:var(--panel2);
  border:1px solid var(--line2);border-radius:var(--r-pill);padding:4px 11px}
.cat-sub{margin-top:10px;max-width:460px}
.cat-curve{display:block;background:var(--panel2);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px 12px}
.cat-curve:hover{text-decoration:none;border-color:var(--accent)}
.cat-curve-h{font-size:12.5px;font-weight:700;color:var(--txt);margin-bottom:2px;display:flex;justify-content:space-between;gap:8px}

/* ---------- category-nav chips (icon + colour) ---------- */
.catchip-row{display:flex;gap:8px;flex-wrap:wrap}
.catchip{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--r-pill);
  border:1px solid var(--line2);background:var(--panel);color:var(--txt2);font-weight:700;font-size:13.5px;transition:all .14s}
.catchip .tg{width:14px;height:14px;color:var(--tp,var(--accent))}
.catchip:hover{text-decoration:none;border-color:var(--tp,var(--accent));color:var(--txt)}
.catchip.on{background:var(--tp,var(--accent));border-color:transparent;color:#fff}
.catchip.on .tg{color:#fff}
.list-count{margin:2px 0 12px}

/* ---------- YTW hero in the table ---------- */
.ytw-col{color:var(--accent-ink)}
.ytw-cell{font-size:17px;font-weight:800;color:var(--accent-ink);letter-spacing:-.01em}
.na{font-style:normal}

/* ---------- detail: header glyph + YTW hero zone ---------- */
.dh-left{display:flex;gap:16px;align-items:flex-start}
.dh-glyph{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;
  background:var(--tp,var(--accent));color:#fff;flex-shrink:0;box-shadow:var(--shadow-sm)}
.dh-glyph .tg{width:28px;height:28px}
.dh-due{color:var(--muted);font-weight:600}
.dh-rating{align-self:flex-start}
.hero-zone{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:20px 26px;
  box-shadow:var(--shadow);margin-bottom:20px}
.hz-yield{padding-right:26px;border-right:1px solid var(--line)}
.hz-k{font-size:12px;color:var(--muted);font-weight:700}
.hz-v{font-size:44px;font-weight:800;letter-spacing:-.03em;color:var(--accent-ink);line-height:1.02}
.hz-sub{font-size:12px;color:var(--muted);margin-top:4px}
.hz-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:13px 26px}
.hz-stats .stat{background:transparent;border:0;padding:0;box-shadow:none}
.hz-stats .stat-v{font-size:17px}
.hz-price{text-align:right;padding-left:26px;border-left:1px solid var(--line)}
.hz-pv{font-size:30px;font-weight:800;letter-spacing:-.02em;line-height:1.05}
.hz-prov{font-size:11.5px;color:var(--muted);margin-top:5px;display:flex;gap:6px;justify-content:flex-end;align-items:center}
.hz-auction{font-size:12px;color:var(--txt2);margin-top:8px;padding-top:8px;border-top:1px dashed var(--line2);text-align:right}
.real-tag{display:inline-block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  color:#fff;background:var(--up);border-radius:5px;padding:1px 6px;margin-right:5px}
.sample-pill{display:inline-block;font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  color:#fff;background:var(--warn);border-radius:6px;padding:2px 9px;cursor:help}
.mini-real{font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.03em;color:var(--up);
  background:rgba(18,160,90,.13);border-radius:4px;padding:0 4px;vertical-align:middle}

/* ---------- cash-flow timeline ---------- */
.timeline-card .chart-wrap{overflow:visible}
.timeline .tl-axis{stroke:var(--line2);stroke-width:2}
.timeline .tl-tick{stroke-width:2}
.timeline .tl-tick.up{stroke:var(--accent)}
.timeline .tl-tick.past{stroke:var(--faint)}
.timeline .tl-today{stroke:var(--teal);stroke-width:2;stroke-dasharray:3 3}
.timeline .tl-now{fill:var(--teal);font-size:11px;font-weight:800}
.timeline .tl-issue{fill:var(--muted)}
.timeline .tl-principal{fill:var(--accent)}
.timeline .tl-lab{fill:var(--muted);font-size:11px}
.timeline .tl-cap{fill:var(--txt2);font-size:11.5px;font-weight:600}

/* ---------- transaction facts strip + rate scenario + notes ---------- */
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.fact{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px 16px;box-shadow:var(--shadow-sm)}
.fact-k{font-size:12px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:5px}
.fact-v{font-size:20px;font-weight:800;letter-spacing:-.01em;margin-top:3px}
.fact-s{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.45}
.scen td:first-child{font-weight:600}
.up{color:var(--up);font-weight:700} .down{color:var(--down);font-weight:700}
.risk-list{margin:6px 0 0;padding-left:18px}
.risk-list li{margin:6px 0;color:var(--txt2)}
.notes-card .mini h3{margin-top:14px}
.notes-card .mini h3:first-child{margin-top:0}

/* ---------- external action button + legends ---------- */
.btn.ext{gap:8px}
.ext-ico{width:14px;height:14px}
.actions{margin-top:16px}
.legend-pills{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:6px 0 4px}
.ig-divider{font-size:10px;font-weight:800;color:var(--down);letter-spacing:.04em;padding:0 4px}

/* ---------- AI prompts page ---------- */
.prompt-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px}
.prompt{margin-bottom:0}
.prompt-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.prompt-head h2{font-size:15px}
.copy-btn{flex-shrink:0;padding:6px 14px;border-radius:var(--r-pill);border:1px solid var(--line2);
  background:var(--panel2);color:var(--accent-ink);font-weight:700;font-size:12.5px;cursor:pointer;transition:all .14s}
.copy-btn:hover{background:var(--accent);color:#fff;border-color:transparent}
.copy-btn.copied{background:var(--up);color:#fff;border-color:transparent}
.prompt-text{margin:0;white-space:pre-wrap;word-break:break-word;font-family:var(--mono);font-size:12.5px;
  line-height:1.55;color:var(--txt2);background:var(--panel2);border:1px solid var(--line);
  border-radius:var(--r-sm);padding:13px 15px}
.agent-tips{margin:0;padding-left:20px}
.agent-tips li{margin:8px 0;color:var(--txt2)}

/* ---------- Learn page ---------- */
.learn .lcard{position:relative;padding-left:64px}
.lnum{position:absolute;left:20px;top:22px;width:30px;height:30px;border-radius:9px;display:grid;
  place-items:center;background:var(--accent);color:#fff;font-weight:800;font-size:15px}
.lcard h2{font-size:19px;margin-bottom:6px}
.lcard p{color:var(--txt2);margin:10px 0 0}
.learn-fig{margin:16px 0 6px;background:var(--panel2);border:1px solid var(--line);border-radius:var(--r-sm);padding:14px}
.learn-fig .lf{width:100%;height:auto;display:block}
.two-fig{display:grid;grid-template-columns:1fr 1fr;gap:14px;background:transparent;border:0;padding:0}
.two-fig>div{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r-sm);padding:10px}
.lf-axis{stroke:var(--line2);stroke-width:2}
.lf-tick{stroke:var(--accent);stroke-width:2.5}
.lf-dot-out{fill:var(--down)} .lf-dot-in{fill:var(--up)}
.lf-lab{fill:var(--txt2);font-size:12px;font-weight:600}
.lf-sub{fill:var(--muted);font-size:11px}
.lf-cap{fill:var(--accent-ink);font-size:12px;font-weight:700}
.seg-bill{fill:#3b6fd4} .seg-note{fill:#2a55c8} .seg-bond{fill:#1b3a8f}
.lf-pivot{fill:var(--muted)}
.lf-beam{stroke:var(--txt2);stroke-width:5;stroke-linecap:round}
.lf-up{fill:var(--up)} .lf-down{fill:var(--down)}
.lf-onlab{fill:#fff;font-size:11px;font-weight:800}
.lf-line{stroke:var(--accent);stroke-width:3;stroke-linecap:round}
.lf-line-inv{stroke:var(--down)}
.lf-bar{fill:var(--panel);stroke:var(--line2);stroke-width:1.5}
.lf-down-bar{fill:var(--down);opacity:.85}
.ltypes{list-style:none;margin:8px 0 0;padding:0}
.ltypes li{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--line)}
.ltypes li:last-child{border-bottom:0}
.ltypes li span{color:var(--txt2);font-size:14px}
.ldefs{display:grid;gap:14px;margin-top:8px}
.ldef-k{display:inline-block;font-weight:800;color:var(--accent-ink);margin-bottom:2px}
.ldefs p{margin:0;color:var(--txt2)}
.lread{margin:8px 0 0;padding:0;list-style:none}
.lread li{display:flex;align-items:flex-start;gap:9px;margin:10px 0;color:var(--txt2)}
.lread li>span:first-child{flex-shrink:0;margin-top:1px}
.ldecide{margin:8px 0 0;padding-left:20px}
.ldecide li{margin:10px 0;color:var(--txt2)}
.lcard .hero-cta{margin-top:18px}

/* ---------- corporates: issuer directory + issuer header + logos ---------- */
.sample-banner{background:rgba(201,138,22,.10);border-color:color-mix(in srgb,var(--warn) 38%,transparent);margin-bottom:18px}
.ilogo{position:relative;display:inline-grid;place-items:center;border-radius:12px;overflow:hidden;
  background:var(--panel2);border:1px solid var(--line2);flex-shrink:0}
.ilogo-md{width:46px;height:46px} .ilogo-lg{width:66px;height:66px}
.ilogo img{width:100%;height:100%;object-fit:contain;background:#fff}
.ilogo-fallback{display:none;font-weight:800;color:var(--accent-ink);font-size:17px;letter-spacing:.02em}
.ilogo.failed{background:var(--accent-soft)} .ilogo.failed .ilogo-fallback{display:block}
.ticker-pill{font-family:var(--mono);font-size:12px;font-weight:700;background:var(--panel2);
  border:1px solid var(--line2);color:var(--txt2);padding:3px 9px;border-radius:6px;white-space:nowrap}

/* homepage asset-class cards */
.ac-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:22px}
.ac-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;
  box-shadow:var(--shadow);border-top:3px solid var(--accent);transition:transform .12s,box-shadow .15s}
.ac-card:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.ac-treasury{border-top-color:var(--accent)} .ac-corp{border-top-color:#475569} .ac-agency{border-top-color:#6d44aa}
.ac-k{font-size:13px;font-weight:700;color:var(--muted)}
.ac-v{font-size:26px;font-weight:800;letter-spacing:-.02em;margin:2px 0 4px}
.ac-name{font-size:18px;font-weight:800;letter-spacing:-.01em;color:var(--txt);margin-bottom:6px}
.ac-s{font-size:12.5px;color:var(--muted);line-height:1.45}
.ac-go{display:inline-block;margin-top:13px;font-size:13px;font-weight:700;color:var(--accent-ink)}
.ac-card:hover .ac-go{color:var(--accent)}

.sector-block{margin-bottom:24px}
.sector-head{font-size:14px;font-weight:800;letter-spacing:.01em;color:var(--txt2);margin:0 0 12px;
  display:flex;align-items:center;gap:9px;text-transform:uppercase}
.sector-n{font-size:12px;font-weight:700;color:var(--muted);background:var(--panel2);
  border:1px solid var(--line2);border-radius:var(--r-pill);padding:1px 9px}
.issuer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.issuer-card{display:flex;flex-direction:column;gap:13px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .15s}
.issuer-card:hover{text-decoration:none;transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.ic-head{display:flex;align-items:center;gap:12px}
.ic-id{min-width:0}
.ic-name{font-weight:800;font-size:15px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ic-sub{display:flex;align-items:center;gap:8px;margin-top:4px;flex-wrap:wrap}
.ic-ind{font-size:11.5px;color:var(--muted)}
.ic-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ic-stat{font-size:12.5px;color:var(--txt2)} .ic-stat b{color:var(--accent-ink)}

.issuer-head{display:flex;gap:18px;align-items:center;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:22px 24px;box-shadow:var(--shadow);margin-bottom:16px}
.ih-body{min-width:0}
.ih-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}
.ih-top h1{font-size:24px;letter-spacing:-.02em}
.bond-desc{font-weight:600;font-size:13px}

/* ---------- corporate bond detail: feed slots, model spread, credit context ---------- */
.feed-tag{display:inline-block;font-size:11px;font-weight:800;color:var(--warn);
  background:rgba(201,138,22,.12);border:1px dashed color-mix(in srgb,var(--warn) 50%,transparent);
  border-radius:6px;padding:1px 8px;cursor:help;letter-spacing:.02em}
.market-card .fact-v.feed-v{font-size:14px;font-weight:600}
.spread-note{margin-top:13px;padding:11px 14px;background:var(--panel2);border:1px solid var(--line);
  border-left:3px solid var(--warn);border-radius:var(--r-sm)}
.model-spread{font-weight:800;color:var(--warn);font-size:13px;margin-right:6px;text-transform:uppercase;letter-spacing:.02em}
.cc-top{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-bottom:13px}
.cc-meta{font-size:13px;color:var(--txt2)}
.cc-grid{margin-top:4px}
.cc-news-h{font-size:13px;font-weight:800;color:var(--txt2);margin:16px 0 0;text-transform:uppercase;letter-spacing:.03em}
.cc-news{list-style:none;padding:0;margin:8px 0 0}
.cc-news li{padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
.cc-news li:last-child{border-bottom:0}

/* ---------- consistent keyboard focus ---------- */
.pill:focus-visible,.catchip:focus-visible,.chip:focus-visible,.btn:focus-visible,
.theme-btn:focus-visible,.cusip-link:focus-visible,.link:focus-visible,a:focus-visible,
.rbadge:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:10px;text-decoration:none}

/* ---------- responsive ---------- */
/* tablet: collapse two-column layouts to one */
@media (max-width:960px){
  .cols,.two,.hist-grid,.cat-head,.hero-zone,.facts,.prompt-grid,.two-fig,.ldefs,
  .issuer-grid,.ac-row{grid-template-columns:1fr}
  .learn .lcard{padding-left:20px}
  .issuer-head{flex-direction:column;align-items:flex-start}
  .hz-yield{border-right:0;border-bottom:1px solid var(--line);padding-right:0;padding-bottom:14px}
  .hz-price{border-left:0;border-top:1px solid var(--line);padding-left:0;padding-top:14px;text-align:left}
  .hz-prov{justify-content:flex-start}
  .detail-head{flex-direction:column;align-items:stretch}.price-hero{text-align:left}
}

/* phone: stacked header with swipeable nav, scrollable tables, sized type */
@media (max-width:720px){
  .wrap{padding:0 14px}
  /* header: brand row, then full-width search + theme, then a horizontal-scroll nav */
  .topbar .bar{gap:10px;min-height:0;padding:9px 0;align-items:center}
  .brand{order:1}
  .bar-right{order:2;width:100%;gap:10px}
  .search{flex:1}
  .search input{width:100%}
  .search-results{width:100%;left:0;right:auto}
  /* wrap all menu buttons onto as many rows as needed — every item visible, no scroll */
  .menu{order:3;width:100%;flex-wrap:wrap;gap:8px}
  .pill{flex:0 0 auto;white-space:nowrap;padding:7px 13px;font-size:13px}
  /* wide data tables scroll sideways instead of hiding or crushing columns */
  .table-card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.grid:not(.compact){min-width:600px}
  /* keep small tiles 2-up, not one giant stacked column */
  .metric-grid,.hz-stats,.stat-row{grid-template-columns:1fr 1fr}
  .type-grid,.hl-grid{grid-template-columns:1fr}
  /* typography + spacing for small screens */
  .hero{padding:26px 20px;border-radius:18px}
  .hero h1{font-size:26px} .lede{font-size:15px}
  .page-head h1{font-size:23px}
  .card{padding:16px 16px}
  .hz-v{font-size:36px} .ph-v{font-size:26px}
  .detail-head,.issuer-head,.cat-head{padding:18px 16px}
  .detail-head h1,.issuer-head .ih-top h1,.cat-head h1{font-size:21px}
}

/* very small phones: single-column tiles */
@media (max-width:420px){
  .stat-row,.metric-grid,.hz-stats{grid-template-columns:1fr}
  .hero h1{font-size:23px} .hz-v{font-size:32px}
  .brand-tag{display:none}
}

/* ===== sortable tables (click a header to sort) ===== */
table.sortable thead th.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
table.sortable thead th.th-sort:hover{color:var(--accent-ink)}
table.sortable thead th[data-dir]{color:var(--accent-ink)}
table.sortable thead th.th-sort::after{content:"\2195";font-size:10px;margin-left:5px;opacity:.4}
table.sortable thead th[data-dir="asc"]::after{content:"\25B2";opacity:.95}
table.sortable thead th[data-dir="desc"]::after{content:"\25BC";opacity:.95}
table.sortable thead th.th-sort:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}

/* ===== directory "group by" toggle (sector / rating) ===== */
.sort-toggle{display:inline-flex;align-items:center;gap:7px;margin:0 0 16px;flex-wrap:wrap}
.sort-toggle .st-label{font-size:12px;color:var(--muted);font-weight:600;margin-right:2px}
.sort-toggle .st{padding:6px 14px;border-radius:var(--r-pill);border:1px solid var(--line2);
  background:var(--panel);font-size:13px;font-weight:600;color:var(--txt2)}
.sort-toggle .st:hover{border-color:var(--accent);color:var(--accent-ink);text-decoration:none}
.sort-toggle .st.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ===== public-access traffic light ===== */
.apill{display:inline-flex;align-items:center;gap:7px;padding:5px 11px;border-radius:var(--r-pill);
  font-size:12px;font-weight:700;color:var(--txt);border:1px solid var(--line2);
  background:var(--panel);vertical-align:middle;cursor:default}
.apill.big{font-size:13px;padding:6px 13px}
.apill .adot{width:9px;height:9px;border-radius:50%;flex:0 0 auto}
.apill.big .adot{width:10px;height:10px}
.a-public{background:color-mix(in srgb,#22c55e 13%,var(--panel));border-color:color-mix(in srgb,#22c55e 42%,var(--line))}
.a-public .adot{background:#22c55e;box-shadow:0 0 0 3px color-mix(in srgb,#22c55e 22%,transparent)}
.a-limited{background:color-mix(in srgb,#f59e0b 14%,var(--panel));border-color:color-mix(in srgb,#f59e0b 48%,var(--line))}
.a-limited .adot{background:#f59e0b;box-shadow:0 0 0 3px color-mix(in srgb,#f59e0b 22%,transparent)}
.a-institutional{background:color-mix(in srgb,#ef4444 13%,var(--panel));border-color:color-mix(in srgb,#ef4444 46%,var(--line))}
.a-institutional .adot{background:#ef4444;box-shadow:0 0 0 3px color-mix(in srgb,#ef4444 22%,transparent)}
.a-unknown{color:var(--muted)}
.a-unknown .adot{background:var(--faint)}

/* ===== Learn page: access traffic-light list + CUSIP anatomy ===== */
.laccess{list-style:none;padding:0;margin:14px 0 4px;display:grid;gap:11px}
.laccess li{display:flex;gap:11px;align-items:flex-start;line-height:1.5}
.laccess .ld{width:11px;height:11px;border-radius:50%;flex:0 0 auto;margin-top:5px}
.laccess .ld-g{background:#22c55e} .laccess .ld-a{background:#f59e0b} .laccess .ld-r{background:#ef4444}
.cusip-anatomy{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}
.cusip-anatomy span{display:flex;flex-direction:column;align-items:center;gap:6px}
.cusip-anatomy small{font-size:11px;color:var(--muted);font-weight:600}

/* ===== CUSIP — the headline transact-with-it feature ===== */
.cusip-card{
  border:1px solid color-mix(in srgb, var(--accent) 40%, var(--line));
  background:
    radial-gradient(135% 150% at 0% 0%, var(--accent-soft), transparent 58%),
    var(--panel);
  scroll-margin-top:90px;
}
.cusip-top{display:flex;gap:22px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cusip-intro{flex:1 1 340px;min-width:0}
.cusip-eyebrow{font-size:11px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:5px}
.cusip-card h2{font-size:23px;line-height:1.15;margin:0 0 7px;letter-spacing:-.015em}
.cusip-lead{color:var(--txt2);margin:0;max-width:64ch;line-height:1.5}
.cusip-eg,.cusip-steps code,.cusip-foot code{
  font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-weight:700;font-size:.9em;
  white-space:nowrap;padding:1px 7px;border-radius:6px;color:var(--txt);
  background:color-mix(in srgb, var(--accent) 13%, var(--panel));
  border:1px solid color-mix(in srgb, var(--accent) 28%, var(--line));
}
.cusip-btn{flex:0 0 auto;font-size:15px;padding:14px 22px}
.cusip-steps{list-style:none;margin:20px 0 0;padding:0;display:grid;gap:11px}
.cusip-steps li{display:flex;gap:12px;align-items:flex-start;color:var(--txt2);line-height:1.45}
.cstep-n{flex:0 0 auto;width:23px;height:23px;border-radius:50%;background:var(--accent);color:#fff;
  font-size:12.5px;font-weight:800;display:grid;place-items:center;margin-top:1px}
.cusip-foot{margin:18px 0 0;padding-top:13px;border-top:1px solid var(--line)}
@media (max-width:640px){
  .cusip-top{align-items:flex-start}
  .cusip-btn{width:100%;justify-content:center}
  .cusip-card h2{font-size:20px}
}
