/* ─────────────────────────────────────────────────────────────────
   CU Wire Data — Platform design system (PitchBook/Carta-grade)
   Sidebar-driven data product. Cream + bold plum. Plex Sans + Spline mono.
   Used by the new platform pages (institution list, profile, benchmark).
   Light-only by design.
   ───────────────────────────────────────────────────────────────── */
:root{
  --bg:#f7f3ec; --surface:#fbf8f1; --surface2:#efe9de; --rule:#d9ceba; --rule-soft:#e8ddc6;
  --ink:#1c1814; --ink2:#4a4239; --ink3:#8a7f6f;
  --plum:#5b2b54; --plum-deep:#43203d; --plum-tint:rgba(91,43,84,.10);
  --olive:#4a6b3f; --brick:#a33d3d; --ochre:#7a5a2a;
  --pfont:'IBM Plex Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --pmono:'Spline Sans Mono','SF Mono',monospace;
  --r:6px;
}
.pf *,.pf *::before,.pf *::after{box-sizing:border-box;margin:0;padding:0}
.pf{font-family:var(--pfont);color:var(--ink);background:var(--bg);font-size:13px;line-height:1.45;-webkit-font-smoothing:antialiased}
.pf .m{font-family:var(--pmono);font-variant-numeric:tabular-nums}

/* App shell */
.pf .app{display:grid;grid-template-columns:208px 1fr;min-height:100vh}
.pf .sidebar{background:var(--surface);border-right:1px solid var(--rule);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;padding:14px 12px;overflow-y:auto}
.pf .brand{font-size:17px;font-weight:700;letter-spacing:-.01em;color:var(--ink);padding:2px 8px 14px;text-decoration:none;display:block}
.pf .brand b{color:var(--plum)}
.pf .s-search{font-family:var(--pfont);width:100%;background:var(--bg);border:1px solid var(--rule);border-radius:var(--r);padding:7px 10px;font-size:12px;color:var(--ink);margin-bottom:14px;outline:none}
.pf .s-search:focus{border-color:var(--plum)}
.pf .s-search::placeholder{color:var(--ink3)}
.pf .s-group{font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);padding:10px 8px 5px}
.pf .ni{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink2);padding:7px 10px;border-radius:var(--r);text-decoration:none;margin-bottom:1px}
.pf .ni:hover{background:var(--surface2);color:var(--ink)}
.pf .ni.on{background:var(--plum);color:var(--surface);font-weight:600}
.pf .ni .dot{width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.55;flex-shrink:0}
.pf .s-foot{margin-top:auto;border-top:1px solid var(--rule-soft);padding:12px 8px 2px;display:flex;justify-content:space-between;align-items:center}
.pf .s-foot .pd{font-size:11px}.pf .s-foot .pd b{color:var(--plum)}
.pf .s-acct{width:26px;height:26px;border-radius:50%;background:var(--plum-tint);color:var(--plum);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:11px}

/* Main + topbar */
.pf .main{padding:0 0 40px;min-width:0}
.pf .topbar{display:flex;align-items:center;gap:14px;padding:11px 26px;border-bottom:1px solid var(--rule);background:var(--surface);position:sticky;top:0;z-index:5}
.pf .crumb{font-size:12px;color:var(--ink3)}
.pf .crumb a{color:var(--ink3);text-decoration:none}.pf .crumb a:hover{color:var(--plum)}
.pf .crumb .sep{color:var(--rule);margin:0 5px}
.pf .crumb .cur{color:var(--ink2)}
/* Mobile drawer nav (hamburger injected by platform-nav.js; hidden on desktop). */
.pf .pf-burger{display:none;align-items:center;justify-content:center;width:40px;height:40px;flex:none;padding:0;margin:-3px 2px -3px 0;border:1px solid var(--rule);border-radius:var(--r);background:var(--surface);color:var(--ink);cursor:pointer}
.pf .pf-burger svg{width:20px;height:20px}
.pf-backdrop{position:fixed;inset:0;background:rgba(28,24,20,.42);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:55}
body.pf.nav-open{overflow:hidden}
body.pf.nav-open .pf-backdrop{opacity:1;pointer-events:auto}
.pf .src{margin-left:auto;font-size:10px;color:var(--ink3);border:1px solid var(--rule);border-radius:4px;padding:2px 8px}
.pf .wrap{padding:22px 26px;max-width:1180px}
.pf .wrap.wide{max-width:1480px}

/* Page heads */
.pf .head{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:3px}
.pf .head h1{font-size:26px;font-weight:700;letter-spacing:-.015em;color:var(--ink);line-height:1.1}
.pf .badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;margin-top:5px}
.pf .badge.ok{color:var(--olive);background:rgba(74,107,63,.10)}
.pf .badge.warn{color:var(--ochre);background:rgba(122,90,42,.10)}
.pf .badge.bad{color:var(--brick);background:rgba(163,61,61,.10)}
.pf .submeta{font-size:12px;color:var(--ink3);margin-bottom:20px}
.pf .submeta b{color:var(--ink2);font-weight:500}

/* Stat bar (aggregate) */
.pf .statbar{display:flex;gap:28px;flex-wrap:wrap;align-items:baseline;margin-bottom:18px}
.pf .statbar .sv{font-family:var(--pmono);font-variant-numeric:tabular-nums;font-size:22px;color:var(--ink)}
.pf .statbar .sl{font-size:11px;color:var(--ink3)}

/* KPI grid */
.pf .kpis{display:grid;grid-template-columns:repeat(5,1fr);border:1px solid var(--rule);border-radius:8px;overflow:hidden;margin-bottom:26px;background:var(--rule);gap:1px}
.pf .kpi{background:var(--surface);padding:13px 16px}
.pf .kpi .l{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3)}
.pf .kpi .v{font-family:var(--pmono);font-variant-numeric:tabular-nums;font-size:21px;color:var(--ink);margin-top:4px}
.pf .kpi .d{font-family:var(--pmono);font-size:11px;margin-top:2px;color:var(--ink3)}
.pf .kpi .d.up{color:var(--olive)}.pf .kpi .d.dn{color:var(--brick)}

/* Section label */
.pf .sect{display:flex;align-items:baseline;gap:10px;margin:0 0 12px}
.pf .sect h2{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--plum)}
.pf .sect .note{font-size:12px;color:var(--ink3)}
.pf .sect::before{content:"";width:3px;height:14px;background:var(--plum);border-radius:2px;align-self:center}

/* Toolbar + filter pills */
.pf .toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.pf .filters{display:inline-flex;border:1px solid var(--rule);border-radius:6px;overflow:hidden}
.pf .filters a{font-family:var(--pmono);font-size:11px;padding:5px 11px;color:var(--ink2);text-decoration:none;border-left:1px solid var(--rule)}
.pf .filters a:first-child{border-left:0}
.pf .filters a.on{background:var(--plum);color:var(--surface);font-weight:500}
.pf .toolbar .count{margin-left:auto;font-family:var(--pmono);font-size:11px;color:var(--ink3)}
.pf .s-sel{font-family:var(--pmono);font-size:11px;padding:5px 9px;border:1px solid var(--rule);border-radius:6px;background:var(--surface);color:var(--ink2);cursor:pointer;outline:none;max-width:240px}
.pf .s-sel:focus{border-color:var(--plum)}

/* Tables */
.pf table{width:100%;border-collapse:collapse;font-size:13px}
.pf .tscroll{overflow-x:auto}
.pf thead th{font-size:9.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);padding:8px 10px;border-bottom:1px solid var(--rule);text-align:right;white-space:nowrap;cursor:pointer}
.pf thead th.l{text-align:left}
.pf thead th.sort::after{content:" ↓";color:var(--plum)}
.pf thead th.sorted::after{content:" ↓";color:var(--plum)}
.pf thead th.sorted.asc::after{content:" ↑";color:var(--plum)}
.pf tbody td{padding:9px 10px;border-bottom:1px solid var(--rule-soft);text-align:right;white-space:nowrap;font-family:var(--pmono);font-variant-numeric:tabular-nums}
.pf tbody td.l{text-align:left;font-family:var(--pfont)}
.pf tbody td.name{font-weight:600;color:var(--ink)}
.pf tbody td.name a{color:var(--ink);text-decoration:none}
.pf tbody td.name a:hover{color:var(--plum)}
.pf tbody td.muted{color:var(--ink3)}
.pf tbody td .rank{color:var(--ink3);font-family:var(--pmono)}
.pf tbody tr:hover{background:var(--surface)}
.pf td.pos{color:var(--olive)}.pf td.neg{color:var(--brick)}.pf td.warn-c{color:var(--ochre)}

/* Percentile / progress bar */
.pf .bar{display:inline-block;width:78px;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden;vertical-align:middle;margin-right:7px}
.pf .bar i{display:block;height:100%;background:var(--plum)}
.pf .bar i.warn{background:var(--brick)}
.pf .pct{color:var(--ink2)}

/* Health dot (used sparingly) */
.pf .h{display:inline-block;width:7px;height:7px;border-radius:50%}
.pf .h.ok{background:var(--olive)}.pf .h.warn{background:var(--ochre)}.pf .h.bad{background:var(--brick)}

/* Two-up panels */
.pf .grid2{display:grid;grid-template-columns:1.3fr 1fr;gap:26px;margin-top:30px}
.pf .panel{border:1px solid var(--rule);border-radius:8px;overflow:hidden}
.pf .panel h3{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink3);padding:11px 14px;border-bottom:1px solid var(--rule-soft);background:var(--surface)}
.pf .row{display:flex;justify-content:space-between;padding:9px 14px;border-bottom:1px solid var(--rule-soft);font-size:13px}
.pf .row:last-child{border-bottom:0}
.pf .row .k{color:var(--ink2)} .pf .row .v{color:var(--ink);font-family:var(--pmono);font-variant-numeric:tabular-nums}

/* trend bars */
.pf .trend{display:flex;align-items:flex-end;gap:5px;height:78px;padding:16px 14px 12px}
.pf .trend .b{flex:1;background:var(--plum-tint);border-radius:2px 2px 0 0}
.pf .trend .b.last{background:var(--plum)}

/* Pager */
.pf .pager{display:flex;gap:4px;margin-top:18px;align-items:center;flex-wrap:wrap}
.pf .pg{font-family:var(--pmono);font-size:11px;min-width:26px;height:26px;padding:0 7px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--rule);border-radius:5px;color:var(--ink2);text-decoration:none;cursor:pointer;background:var(--surface)}
.pf .pg:hover{border-color:var(--plum);color:var(--plum)}
.pf .pg.on{background:var(--plum);border-color:var(--plum);color:var(--surface);font-weight:600}
.pf .pg.dis{opacity:.4;pointer-events:none}
.pf .pg-el{color:var(--ink3);padding:0 2px}

/* Watchlist star + nav count */
.pf .wl-star{background:none;border:0;cursor:pointer;font-size:14px;line-height:1;color:var(--rule);padding:2px 4px;border-radius:4px}
.pf .wl-star:hover{color:var(--ochre)}
.pf .wl-star.on{color:var(--ochre)}
.pf .ni-count{font-size:11px;font-family:var(--pmono);color:var(--ink3)}
.pf .ni.on .ni-count{color:var(--surface);opacity:.85}
.pf .track-btn{align-self:flex-start;margin-top:5px;font-family:var(--pfont);font-size:12px;padding:5px 12px;border:1px solid var(--rule);border-radius:6px;background:var(--surface);color:var(--ink2);cursor:pointer}
.pf .track-btn:hover{border-color:var(--ochre)}
.pf .track-btn.on{border-color:var(--ochre);color:var(--ochre);background:rgba(122,90,42,.08)}

/* Compare: action button (list) + comparison table */
.pf .acts{white-space:nowrap}
.pf .cmp-btn{background:none;border:1px solid var(--rule);cursor:pointer;font-size:11px;line-height:1;color:var(--ink3);width:18px;height:18px;border-radius:4px;padding:0;margin-right:3px;vertical-align:middle}
.pf .cmp-btn:hover{border-color:var(--plum);color:var(--plum)}
.pf .cmp-btn.on{background:var(--plum);border-color:var(--plum);color:var(--surface)}
.pf .cu-col{min-width:132px}
.pf .cu-col a{color:var(--ink);text-decoration:none;font-weight:600}
.pf .cu-col a:hover{color:var(--plum)}
.pf .cmp-x{background:none;border:0;color:var(--ink3);cursor:pointer;font-size:13px;padding:0 2px}
.pf .cmp-x:hover{color:var(--brick)}
.pf td.metric{color:var(--ink2);font-family:var(--pfont)}
.pf td.best{color:var(--plum);font-weight:600}

@media(max-width:760px){
  .pf .app{grid-template-columns:1fr}
  /* Sidebar becomes an off-canvas drawer (opened by the injected hamburger). */
  .pf .sidebar{position:fixed;top:0;left:0;height:100vh;width:min(82vw,264px);z-index:60;transform:translateX(-100%);transition:transform .22s ease;box-shadow:2px 0 18px rgba(28,24,20,.20)}
  body.pf.nav-open .sidebar{transform:none}
  .pf .pf-burger{display:inline-flex}
  .pf .kpis{grid-template-columns:repeat(2,1fr)}
  .pf .kpi .v{font-size:18px}
  /* Compact the headline stat bar so it doesn't sprawl down the page on phones. */
  .pf .statbar{gap:5px 16px;margin-bottom:14px}
  .pf .statbar .sv{font-size:17px}
  .pf .grid2{grid-template-columns:1fr}
  .pf .wrap,.pf .topbar{padding-left:16px;padding-right:16px}
  /* Wide data tables already scroll via .tscroll (line ~95); add iOS momentum scroll. */
  .pf .tscroll{-webkit-overflow-scrolling:touch}
}
