/* ════════════════════════════════════════════════════════════════
   PORTFOLIO V6 — ported design-handover stylesheet for the portfolio
   surfaces (Console / Ledger / Triage). Namespaces: .pf-*  .tri-*  .scr-sort
   Root scope for the token bridge: .pf-page

   REQUIRES: theme.css loaded first (provides --bg-deep, --surface-deep,
   --quartet-cyan, --quartet-pos, --quartet-neg, --font-quartet-mono, etc.).
   This file does NOT ship styles-v6.css base tokens — it bridges the
   handover's short-form variables (--bg, --surface, --cyan, --ink, …)
   to the production theme.css tokens via a variable map on .pf-page.

   Because custom properties inherit, defining the bridge on .pf-page makes
   every short-form variable available to all descendant component classes.
   The component class selectors themselves stay GLOBAL (un-nested) since
   they are uniquely prefixed (.pf-* / .tri-* / .scr-sort).

   Theming: surfaces / ink / lines bridge to the theme-aware --*-deep tokens
   (light + dark handled by theme.css). SEMANTIC colors (pos/neg/amber/
   violet/indigo/coral) and the ACCENT (cyan / --da-accent*) are FIXED by
   design and bridge to the --quartet-* family.
   ──────────────────────────────────────────────────────────────────
   Sources merged below:
     • styles-v6.css   — .pf-* portfolio block + .scr-sort + .chip-delta
     • pf-modules.css  — redesigned portfolio modules (full file)
     • pf-cash.css     — cash workspace + modal/form system (full file)
     • pf-triage.css   — Direction B · Triage two-column overview (full file)
   ════════════════════════════════════════════════════════════════ */

/* ── Variable bridge ────────────────────────────────────────────
   Maps every short-form variable the portfolio CSS references to its
   production theme.css token. Defined on .pf-page so it cascades to all
   .pf-* / .tri-* / .scr-sort descendants.
   ─────────────────────────────────────────────────────────────── */
.pf-page {
  /* Surfaces — theme-aware quartet palette */
  --bg:         var(--bg-deep);
  --bg-2:       var(--surface-deep);
  --surface:    var(--surface-deep);
  --surface-2:  var(--surface-deep-2);
  --surface-hi: var(--surface-deep-hi);

  /* Lines / borders */
  --line:       var(--line-deep);
  --line-2:     var(--line-deep-2);

  /* Text */
  --ink:        var(--ink-deep);
  --ink-2:      var(--ink-deep-2);
  --muted:      var(--muted-deep);
  --muted-2:    var(--muted-deep-2);
  --faint:      var(--faint-deep);

  /* Accent: cyan (FIXED, not themed) */
  --cyan:           var(--quartet-cyan);
  --cyan-2:         var(--quartet-cyan-2);
  --accent-fill:    var(--quartet-cyan-fill);
  --accent-border:  var(--quartet-cyan-border);

  /* da-accent family (portfolio modules accent) — aliases cyan */
  --da-accent:        var(--quartet-cyan);
  --da-accent-2:      var(--quartet-cyan-2);
  --da-accent-fill:   var(--quartet-cyan-fill);
  --da-accent-border: var(--quartet-cyan-border);
  --da-accent-ink:    #06222a;

  /* Chromatic accents (FIXED) */
  --indigo:     var(--quartet-indigo);
  --violet:     var(--quartet-violet);
  --amber:      var(--quartet-amber);
  --coral:      var(--quartet-coral);

  /* Semantic (FIXED) */
  --pos:        var(--quartet-pos);
  --pos-fill:   var(--quartet-pos-fill);
  --pos-border: var(--quartet-pos-border);
  --neg:        var(--quartet-neg);
  --neg-fill:   var(--quartet-neg-fill);
  --neg-border: var(--quartet-neg-border);

  /* Typography */
  --font-mono:  var(--font-quartet-mono);
  --font-sans:  var(--font-quartet);
  --font-body:  var(--font-quartet);

  max-width: 1320px;
  margin: 0 auto;
  padding: 32px 32px 80px;
  font-family: var(--font-body);
  color: var(--ink);
}


/* ════════════════════════════════════════════════════════════════
   ── from styles-v6.css ── PORTFOLIO PAGE (.pf-*) + .chip-delta
   ════════════════════════════════════════════════════════════════ */

/* Eyebrow + page hero */
.pf-eyebrow {
  font-size: 10.5px; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.20em;
  font-weight: 600;
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 14px;
}
.pf-eyebrow .pulse {
  display: inline-block; width: 6px; height: 6px; border-radius: 999px;
  background: var(--cyan);
  animation: capital-pulse 2.4s ease-out infinite;
}
.pf-eyebrow .as-of {
  font-weight: 500; color: var(--muted-2); letter-spacing: 0.10em;
  font-family: var(--font-mono); font-size: 10.5px;
}

.pf-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 48px;
  margin-bottom: 48px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--line-2);
}
.pf-hero-currency-label {
  font-family: var(--font-mono);
  font-size: 13px; color: var(--muted);
  letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500;
  margin-bottom: 8px;
}
.pf-hero-value {
  font-family: var(--font-mono);
  font-size: 96px; font-weight: 500;
  letter-spacing: -0.045em;
  line-height: 0.92;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.pf-hero-currency-suffix { color: var(--muted-2); font-size: 32px; margin-left: 8px; font-weight: 400; }
.pf-hero-subline {
  margin-top: 22px;
  display: flex; align-items: baseline; gap: 18px; flex-wrap: wrap;
  font-size: 13px; color: var(--muted);
}
.pf-hero-subline .chip-delta {
  display: inline-flex; align-items: baseline; gap: 6px;
  padding: 6px 12px; border-radius: 2px;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-size: 12px; font-weight: 500;
  border: 1px solid;
}
.pf-hero-subline .chip-delta.pos { color: var(--pos); border-color: var(--pos-border); background: var(--pos-fill); }
.pf-hero-subline .chip-delta.neg { color: var(--neg); border-color: var(--neg-border); background: var(--neg-fill); }
.pf-hero-subline .label {
  font-size: 10px; color: var(--muted-2);
  text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600;
  margin-right: 2px;
}

/* Period selector */
.pf-periods {
  display: flex; gap: 0;
  border: 1px solid var(--line-2);
  border-radius: 3px;
  overflow: hidden;
  width: max-content;
  margin-top: 24px;
}
.pf-periods button {
  padding: 8px 16px;
  background: transparent; border: 0;
  border-right: 1px solid var(--line-2);
  font-family: inherit;
  font-size: 11px; color: var(--muted); font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  cursor: pointer;
  transition: color .15s, background .15s;
}
.pf-periods button:last-child { border-right: 0; }
.pf-periods button { white-space: nowrap; }
.pf-periods button:hover { color: var(--ink); background: var(--bg-2); }
.pf-periods button.active { color: var(--cyan); background: var(--accent-fill); }

/* Hero right side — performance triplet */
.pf-hero-perf {
  display: grid;
  grid-template-rows: repeat(3, 1fr);
  gap: 14px;
  align-self: stretch;
}
.pf-perf-card {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 18px 20px;
  border: 1px solid var(--line-2);
  border-radius: 3px;
  background: var(--surface);
}
.pf-perf-card .pf-perf-label {
  font-size: 10px; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.18em; font-weight: 600;
}
.pf-perf-card .pf-perf-since {
  font-family: var(--font-mono);
  font-size: 10.5px; color: var(--muted-2);
  margin-top: 6px; letter-spacing: -0.01em;
}
.pf-perf-card .pf-perf-pct {
  font-family: var(--font-mono);
  font-size: 28px; font-weight: 500;
  letter-spacing: -0.03em;
  text-align: right; line-height: 1;
}
.pf-perf-card .pf-perf-delta {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--muted);
  text-align: right; margin-top: 6px;
  font-variant-numeric: tabular-nums;
}
.pf-perf-card.pos .pf-perf-pct { color: var(--pos); }
.pf-perf-card.neg .pf-perf-pct { color: var(--neg); }
.pf-perf-card.featured {
  border-color: var(--accent-border);
  background: var(--accent-fill);
}

/* Tabs */
.pf-tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid var(--line-2);
  margin-bottom: 36px;
  overflow-x: auto;
  scrollbar-width: none;
}
.pf-tabs::-webkit-scrollbar { display: none; }
.pf-tab {
  padding: 14px 20px 14px 0;
  margin-right: 28px;
  background: transparent; border: 0;
  font-family: inherit;
  font-size: 13px; color: var(--muted); font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .15s, border-color .15s;
}
.pf-tab:hover { color: var(--ink); }
.pf-tab.active { color: var(--ink); border-color: var(--cyan); }
.pf-tab .count {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--muted-2);
  margin-left: 6px;
}

/* Section pattern */
.pf-section { margin-bottom: 48px; }
.pf-section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 14px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--line-2);
}
.pf-section-head h2 {
  margin: 0;
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.20em;
  color: var(--cyan);
}
.pf-section-head .meta {
  font-size: 11px; color: var(--muted-2);
  text-transform: uppercase; letter-spacing: 0.14em; font-weight: 500;
}

/* Timeline chart */
.pf-timeline {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--line-2);
  border-radius: 3px;
  padding: 24px 24px 16px;
}
.pf-timeline svg { width: 100%; height: 280px; display: block; }
.pf-timeline-meta {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 16px;
}
.pf-timeline-meta .label {
  font-size: 10px; color: var(--muted-2);
  text-transform: uppercase; letter-spacing: 0.18em; font-weight: 600;
}
.pf-timeline-meta .value {
  font-family: var(--font-mono);
  font-size: 13px; color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}

/* Allocation: horizontal stacked bar + list */
.pf-alloc { display: grid; grid-template-columns: 1fr; gap: 24px; }
.pf-alloc-bar {
  display: flex; width: 100%; height: 36px;
  border-radius: 2px; overflow: hidden;
  border: 1px solid var(--line-2);
}
.pf-alloc-seg {
  height: 100%; position: relative;
  transition: filter .15s;
  cursor: pointer;
}
.pf-alloc-seg:hover { filter: brightness(1.15); }
.pf-alloc-seg + .pf-alloc-seg { border-left: 1px solid var(--bg); }

.pf-alloc-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 32px;
}
.pf-alloc-row {
  display: grid;
  grid-template-columns: 12px minmax(0, 1.2fr) auto auto auto;
  align-items: center;
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid var(--line);
  cursor: pointer;
  transition: background .15s;
}
.pf-alloc-row:hover { background: var(--bg-2); padding-left: 8px; padding-right: 8px; margin: 0 -8px; border-radius: 3px; }
.pf-alloc-row .swatch {
  width: 10px; height: 10px; border-radius: 2px;
}
.pf-alloc-row .name { font-size: 14px; color: var(--ink); font-weight: 500; }
.pf-alloc-row .pct {
  font-family: var(--font-mono);
  font-size: 12px; color: var(--muted);
  font-variant-numeric: tabular-nums; min-width: 50px; text-align: right;
}
.pf-alloc-row .value {
  font-family: var(--font-mono);
  font-size: 13px; color: var(--ink-2);
  font-variant-numeric: tabular-nums; min-width: 110px; text-align: right;
  letter-spacing: -0.01em;
}
.pf-alloc-row .change {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-variant-numeric: tabular-nums; min-width: 60px; text-align: right;
}
.pf-alloc-row .change.pos { color: var(--pos); }
.pf-alloc-row .change.neg { color: var(--neg); }
.pf-alloc-row .change.zero { color: var(--muted-2); }

/* Distribution side-by-side */
.pf-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 32px;
}
.pf-dist-row {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  align-items: center;
  gap: 16px;
  padding: 12px 0;
  border-top: 1px solid var(--line);
}
.pf-dist-row:first-child { border-top: 0; }
.pf-dist-row .key {
  font-size: 12.5px; color: var(--ink); font-weight: 500;
}
.pf-dist-row .key .sub {
  display: block;
  font-size: 10.5px; color: var(--muted-2); font-weight: 400;
  margin-top: 2px;
}
.pf-dist-row .bar {
  position: relative; height: 6px;
  background: var(--surface-hi);
  border-radius: 999px; overflow: hidden;
}
.pf-dist-row .bar .fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--cyan);
  border-radius: 999px;
}
.pf-dist-row .val {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-2);
  text-align: right;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
.pf-dist-row .val .pct {
  display: block;
  color: var(--muted-2); font-size: 10px;
  letter-spacing: 0;
}

/* Top accounts + activity */
.pf-account-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 18px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
}
.pf-account-row:first-child { border-top: 0; }
.pf-account-row .name { font-size: 14px; color: var(--ink); }
.pf-account-row .kind {
  display: block;
  font-size: 10.5px; color: var(--muted);
  margin-top: 2px;
  text-transform: uppercase; letter-spacing: 0.14em;
}
.pf-account-row .val {
  font-family: var(--font-mono);
  font-size: 14px; color: var(--ink);
  font-variant-numeric: tabular-nums; text-align: right;
  letter-spacing: -0.01em;
}
.pf-account-row .change {
  font-family: var(--font-mono);
  font-size: 11.5px;
  font-variant-numeric: tabular-nums; min-width: 60px; text-align: right;
}
.pf-account-row .change.pos { color: var(--pos); }
.pf-account-row .change.neg { color: var(--neg); }
.pf-account-row .change.zero { color: var(--muted-2); }

.pf-activity-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 16px;
  padding: 12px 0;
  border-top: 1px solid var(--line);
}
.pf-activity-row:first-child { border-top: 0; }
.pf-activity-row .ts {
  font-family: var(--font-mono);
  font-size: 11px; color: var(--muted-2);
  letter-spacing: -0.01em;
  padding-top: 2px;
}
.pf-activity-row .event { font-size: 13px; color: var(--ink); font-weight: 500; }
.pf-activity-row .detail { font-size: 12px; color: var(--muted); margin-top: 2px; }

@media (max-width: 1100px) {
  .pf-hero { grid-template-columns: 1fr; gap: 32px; }
  .pf-hero-perf { grid-template-rows: auto; grid-template-columns: repeat(3, 1fr); }
  .pf-alloc-list { grid-template-columns: 1fr; }
  .pf-two { grid-template-columns: 1fr; gap: 36px; }
  .pf-hero-value { font-size: 72px; }
}
@media (max-width: 680px) {
  .pf-page { padding: 22px 16px 60px; }
  .pf-hero-value { font-size: 56px; }
  .pf-hero-perf { grid-template-columns: 1fr; }
}

/* Pulse keyframe used by .pf-eyebrow .pulse / .pf-snapbar-meta .pulse */
@keyframes capital-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(109, 212, 220, 0.55); }
  70%  { box-shadow: 0 0 0 7px rgba(109, 212, 220, 0); }
  100% { box-shadow: 0 0 0 0 rgba(109, 212, 220, 0); }
}

/* ── from styles-v6.css ── EQUITIES SCREENER sort control (.scr-sort) ── */
.scr-sort {
  display: inline-flex; align-items: stretch;
  background: var(--surface); border: 1px solid var(--line-2); border-radius: 4px;
  overflow: hidden;
}
.scr-sort .label {
  display: flex; align-items: center; padding: 0 12px;
  color: var(--muted); border-right: 1px solid var(--line-2);
}
.scr-sort .label svg { width: 14px; height: 14px; }
.scr-sort select {
  padding: 0 30px 0 10px;
  border: 0; background: transparent; cursor: pointer;
  font-family: inherit; font-size: 13px; color: var(--ink);
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%237c8597' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  color-scheme: dark;
}
.scr-sort select option {
  background: var(--surface);
  color: var(--ink);
}
.scr-sort select:focus { outline: none; }
.scr-sort-dir {
  display: flex; align-items: center; justify-content: center;
  width: 36px; border: 0; border-left: 1px solid var(--line-2);
  background: transparent; color: var(--muted); cursor: pointer;
  font-family: var(--font-mono); font-size: 14px;
  transition: color .15s, background .15s;
}
.scr-sort-dir:hover { color: var(--ink); background: var(--surface-2); }


/* ════════════════════════════════════════════════════════════════
   ── from pf-modules.css ──
   ════════════════════════════════════════════════════════════════ */

/* Make the base .pf-* accent-aware (override hard-coded cyan) */
.pf-eyebrow .pulse { background: var(--da-accent); }
.pf-section-head h2 { color: var(--da-accent); }
.pf-periods button.active { color: var(--da-accent); background: var(--da-accent-fill); }
.pf-tab.active { border-color: var(--da-accent); }
.pf-perf-card.featured { border-color: var(--da-accent-border); background: var(--da-accent-fill); }
.pf-alloc-row .pct { min-width: 46px; }
.pf-dist-row .bar .fill { background: var(--da-accent); }

/* ── Section head action slot ─────────────────────────────────────────── */
.pf-section-head { gap: 16px; flex-wrap: wrap; }
.pf-section-head h2 { display: inline-flex; align-items: center; gap: 10px; }
.pf-pro-tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 7px; border-radius: 2px;
  background: var(--surface-hi); color: var(--muted);
  font-size: 9px; letter-spacing: 0.14em; font-weight: 600;
}
.pf-pro-tag svg { width: 10px; height: 10px; }

/* ── Inline links / buttons ───────────────────────────────────────────── */
.pf-inline-link {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--da-accent); text-decoration: none;
  font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em;
  background: none; border: 0; cursor: pointer; font-family: inherit; padding: 0;
}
.pf-inline-link svg { width: 13px; height: 13px; }
.pf-inline-link:hover { color: var(--da-accent-2); }
.pf-btn-ghost, .pf-btn-accent {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 13px; border-radius: 3px; cursor: pointer;
  font-family: inherit; font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.12em;
  transition: all .15s;
}
.pf-btn-ghost { background: transparent; border: 1px solid var(--line-2); color: var(--ink-2); }
.pf-btn-ghost:hover { border-color: var(--da-accent); color: var(--ink); }
.pf-btn-ghost svg { width: 13px; height: 13px; }
.pf-btn-accent { background: var(--da-accent); border: 0; color: var(--da-accent-ink); }
.pf-btn-accent:hover { background: var(--da-accent-2); }
.pf-btn-accent svg { width: 13px; height: 13px; }
.pf-iconbtn-sm { width: 28px; height: 28px; border-radius: 4px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 1px solid var(--line-2); color: var(--muted); cursor: pointer; }
.pf-iconbtn-sm:hover { color: var(--ink); border-color: var(--line-2); background: var(--surface-2); }
.pf-iconbtn-sm svg { width: 15px; height: 15px; }

/* ── Premium lock veil ────────────────────────────────────────────────── */
.pf-locked { position: relative; border-radius: 4px; overflow: hidden; }
.pf-locked-inner { filter: blur(5px) saturate(0.7); opacity: 0.5; pointer-events: none; user-select: none; }
.pf-locked-veil {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px;
  background: radial-gradient(120% 90% at 50% 40%, transparent 30%, color-mix(in oklab, var(--bg) 62%, transparent) 100%);
  text-align: center; padding: 20px;
}
.pf-locked-veil .ic {
  width: 40px; height: 40px; border-radius: 11px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface); border: 1px solid var(--da-accent-border);
  color: var(--da-accent); box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.pf-locked-veil .ic svg { width: 18px; height: 18px; }
.pf-locked-veil .t { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.16em; color: var(--ink-2); }
.pf-locked-veil .up {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--da-accent-ink); background: var(--da-accent); text-decoration: none;
  font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  padding: 7px 13px; border-radius: 7px; transition: background .15s, transform .15s;
}
.pf-locked-veil .up:hover { background: var(--da-accent-2); transform: translateY(-1px); }
.pf-locked-veil .up svg { width: 13px; height: 13px; }

/* ── Snapshot bar ─────────────────────────────────────────────────────── */
.pf-snapbar {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  padding: 11px 16px; border: 1px solid var(--line-2); border-radius: 4px; background: var(--surface);
}
.pf-snapbar-meta { display: inline-flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--muted); }
.pf-snapbar-meta .pulse { width: 6px; height: 6px; border-radius: 999px; background: var(--da-accent); animation: capital-pulse 2.4s ease-out infinite; }
.pf-snapbar-meta .mono { font-family: var(--font-mono); color: var(--muted-2); letter-spacing: -0.01em; }
.pf-snapbar-meta .dot { color: var(--faint); }
.pf-snapbar-actions { display: inline-flex; align-items: center; gap: 10px; }
.pf-snapmsg { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 500; }
.pf-snapmsg svg { width: 13px; height: 13px; }
.pf-snapmsg.pos { color: var(--pos); }
.pf-snapmsg.amber { color: var(--amber); }
.pf-period-lock { display: inline-flex; margin-left: 5px; }
.pf-period-lock svg { width: 10px; height: 10px; }
.pf-periods button:disabled { opacity: 0.45; cursor: not-allowed; }

/* ── Quick stats ──────────────────────────────────────────────────────── */
.pf-quick {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--line-2); border-radius: 4px; overflow: hidden; background: var(--surface);
}
.pf-quick-cell { padding: 18px 20px; }
.pf-quick-cell + .pf-quick-cell { border-left: 1px solid var(--line-2); }
.pf-quick-label { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600; margin-bottom: 14px; }
.pf-quick-val { font-family: var(--font-mono); font-size: 30px; font-weight: 500; letter-spacing: -0.03em; color: var(--ink); line-height: 1; font-variant-numeric: tabular-nums; }
.pf-quick-val.small { font-size: 20px; letter-spacing: -0.01em; }
.pf-quick-val.pos { color: var(--pos); }
.pf-quick-val.neg { color: var(--neg); }
.pf-quick-sub { font-size: 11px; color: var(--muted-2); margin-top: 10px; }

/* ── Allocation extras ────────────────────────────────────────────────── */
.pf-alloc-list.one-col { grid-template-columns: 1fr; }
.pf-alloc-row .name .acct { color: var(--muted-2); font-size: 11px; margin-left: 8px; font-weight: 400; }

/* Donut */
.pf-donut-wrap { display: flex; justify-content: center; padding: 8px 0 4px; }
.pf-donut { width: 220px; height: 220px; max-width: 100%; }

/* Treemap */
.pf-treemap { position: relative; width: 100%; aspect-ratio: 100 / 56; border-radius: 3px; overflow: hidden; border: 1px solid var(--line-2); }
.pf-tm-cell { position: absolute; cursor: pointer; box-shadow: inset 0 0 0 1px var(--bg); transition: filter .15s; overflow: hidden; }
.pf-tm-cell:hover { filter: brightness(1.12); }
.pf-tm-lbl { position: absolute; left: 9px; top: 8px; display: flex; flex-direction: column; gap: 2px; color: var(--da-accent-ink); }
.pf-tm-lbl b { font-size: 12px; font-weight: 600; letter-spacing: -0.01em; }
.pf-tm-lbl span { font-family: var(--font-mono); font-size: 11px; opacity: 0.8; }

/* MiniBar */
.pf-minibar { position: relative; height: 6px; background: var(--surface-hi); border-radius: 999px; overflow: hidden; }
.pf-minibar .fill { position: absolute; left: 0; top: 0; bottom: 0; border-radius: 999px; }

/* ── Distribution wrapper ─────────────────────────────────────────────── */
.pf-dist .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-dist-row { grid-template-columns: minmax(96px, auto) 1fr auto; }
.pf-dist-row .key { white-space: nowrap; }
.pf-dist-row.tight { grid-template-columns: minmax(0, 1.4fr) 1fr auto; padding: 9px 0; }
.pf-dist-row.tight .key .sub { display: none; }

/* ── Performance triplet horizontal variant ───────────────────────────── */
.pf-hero-perf.cols { grid-template-rows: auto; grid-template-columns: repeat(3, 1fr); }

/* ── Risk ─────────────────────────────────────────────────────────────── */
.pf-risk .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-risk-body { display: grid; grid-template-columns: 160px 1fr; gap: 24px; align-items: center; }
.pf-risk-meta { min-width: 0; }
.pf-risk-verdict { display: inline-block; padding: 4px 10px; border-radius: 2px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 14px; }
.pf-risk-verdict.pos { color: var(--pos); background: var(--pos-fill); border: 1px solid var(--pos-border); }
.pf-risk-verdict.neg { color: var(--neg); background: var(--neg-fill); border: 1px solid var(--neg-border); }
.pf-risk-verdict.amber { color: var(--amber); background: rgba(255,198,109,0.10); border: 1px solid rgba(255,198,109,0.30); }
.pf-risk-row { display: flex; align-items: baseline; justify-content: space-between; padding: 7px 0; border-top: 1px solid var(--line); font-size: 12.5px; color: var(--muted); }
.pf-risk-row b { color: var(--ink); font-family: var(--font-mono); font-weight: 500; letter-spacing: -0.01em; }
.pf-risk-note { font-size: 12px; color: var(--muted); line-height: 1.5; margin: 12px 0 0; }

/* ── Top accounts (rank + who) ────────────────────────────────────────── */
.pf-top .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-top .pf-account-row { grid-template-columns: 22px 1fr auto auto; cursor: pointer; }
.pf-top .pf-account-row:hover { background: var(--bg-2); }
.pf-account-row .rank { font-family: var(--font-mono); font-size: 12px; color: var(--muted-2); }
.pf-account-row .who { min-width: 0; }

/* ── Attention feed ───────────────────────────────────────────────────── */
.pf-attention { display: flex; flex-direction: column; gap: 26px; }
.pf-sig-label { display: flex; align-items: center; gap: 10px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.16em; color: var(--muted); margin-bottom: 14px; }
.pf-sig-label .cnt { font-family: var(--font-mono); font-size: 10px; padding: 2px 7px; border-radius: 999px; background: var(--surface-hi); color: var(--ink-2); letter-spacing: 0; }
.pf-sig-label .cnt.clear { color: var(--pos); background: var(--pos-fill); }
.pf-acts { display: flex; flex-direction: column; gap: 10px; }
.pf-actcard { display: grid; grid-template-columns: 36px 1fr; gap: 14px; padding: 16px 18px; border: 1px solid var(--line-2); border-radius: 4px; background: var(--surface); text-decoration: none; transition: border-color .15s, background .15s; }
.pf-actcard:hover { border-color: var(--da-accent-border); background: var(--surface-2); }
.pf-actcard .ic { width: 36px; height: 36px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; }
.pf-actcard .ic svg { width: 19px; height: 19px; }
.pf-actcard .ic.neg { color: var(--neg); background: var(--neg-fill); }
.pf-actcard .ic.amber { color: var(--amber); background: rgba(255,198,109,0.10); }
.pf-actcard .ic.pos { color: var(--pos); background: var(--pos-fill); }
.pf-actcard .ic.neutral { color: var(--da-accent); background: var(--da-accent-fill); }
.pf-actcard .t { font-size: 14px; font-weight: 600; color: var(--ink); }
.pf-actcard .d { font-size: 12.5px; color: var(--muted); margin-top: 3px; line-height: 1.45; }
.pf-actcard .go { display: inline-flex; align-items: center; gap: 6px; margin-top: 10px; font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; color: var(--da-accent); }
.pf-actcard .go svg { width: 13px; height: 13px; }
.pf-notes { display: flex; flex-direction: column; }
.pf-note { display: grid; grid-template-columns: 28px 1fr auto; align-items: center; gap: 12px; padding: 13px 0; border-top: 1px solid var(--line); text-decoration: none; transition: padding .15s; }
.pf-note:first-child { border-top: 0; }
.pf-note:hover { padding-left: 6px; }
.pf-note .ic { width: 28px; height: 28px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; }
.pf-note .ic svg { width: 15px; height: 15px; }
.pf-note .ic.pos { color: var(--pos); background: var(--pos-fill); }
.pf-note .ic.neutral { color: var(--muted); background: var(--surface-hi); }
.pf-note .b { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.pf-note .t { font-size: 13px; color: var(--ink); font-weight: 500; }
.pf-note .d { font-size: 11.5px; color: var(--muted); }
.pf-note .arr { color: var(--muted-2); }
.pf-note .arr svg { width: 15px; height: 15px; }
.pf-note:hover .arr { color: var(--da-accent); }
/* all clear */
.pf-allclear { display: grid; grid-template-columns: 40px 1fr; gap: 16px; padding: 22px 20px; border: 1px solid var(--pos-border); border-radius: 4px; background: var(--pos-fill); }
.pf-allclear .ic { width: 40px; height: 40px; border-radius: 999px; background: var(--pos-fill); border: 1px solid var(--pos-border); color: var(--pos); display: inline-flex; align-items: center; justify-content: center; }
.pf-allclear .ic svg { width: 20px; height: 20px; }
.pf-allclear .t { font-size: 14.5px; font-weight: 600; color: var(--ink); }
.pf-allclear .d { font-size: 12.5px; color: var(--muted); line-height: 1.5; margin-top: 4px; max-width: 46ch; }
.pf-allclear .nexts { display: flex; gap: 18px; flex-wrap: wrap; margin-top: 14px; }
.pf-allclear .nexts a { display: inline-flex; align-items: center; gap: 6px; color: var(--da-accent); text-decoration: none; font-size: 11.5px; font-weight: 600; }
.pf-allclear .nexts a svg { width: 13px; height: 13px; }

/* ── Dividends ────────────────────────────────────────────────────────── */
.pf-dividend .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-div-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: 3px; overflow: hidden; margin-bottom: 14px; }
.pf-div-stat { background: var(--surface); padding: 14px 16px; }
.pf-div-stat .l { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; margin-bottom: 8px; }
.pf-div-stat .v { font-family: var(--font-mono); font-size: 18px; color: var(--ink); font-variant-numeric: tabular-nums; letter-spacing: -0.02em; }
.pf-div-next { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px; padding: 14px 16px; border: 1px solid var(--line-2); border-radius: 3px; background: var(--surface); }
.pf-div-next-l { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; }
.pf-div-next-r { font-size: 13px; color: var(--ink-2); }
.pf-div-next-r b { font-family: var(--font-mono); color: var(--ink); }
.pf-div-next-r .when { display: block; font-size: 11px; color: var(--muted-2); margin-top: 3px; }
.pf-div-link { margin-top: 14px; }

/* ── Premium trio ─────────────────────────────────────────────────────── */
.pf-trio { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.pf-etf .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-etf-stats { display: flex; gap: 28px; padding: 6px 0 14px; }
.pf-etf-stats div { display: flex; flex-direction: column; gap: 4px; }
.pf-etf-stats b { font-family: var(--font-mono); font-size: 26px; font-weight: 500; color: var(--ink); letter-spacing: -0.02em; }
.pf-etf-stats span { font-size: 10.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; }
.pf-etf-note { display: flex; gap: 9px; align-items: flex-start; font-size: 12px; color: var(--muted); line-height: 1.5; margin: 0 0 14px; padding-top: 14px; border-top: 1px solid var(--line); }
.pf-etf-note svg { width: 15px; height: 15px; color: var(--amber); flex-shrink: 0; margin-top: 1px; }

/* ── Timeline HTML tooltip (calculator-style) + plot ──────────────────── */
.pf-tl-plot { position: relative; }
.pf-tl-plot svg { cursor: crosshair; }
.pf-tl-tip { position: absolute; top: 4px; z-index: 6; pointer-events: none; min-width: 130px; background: var(--bg); border: 1px solid var(--line-2); border-radius: 6px; box-shadow: 0 12px 28px rgba(0,0,0,0.45); padding: 9px 11px; }
.pf-tl-tip.right { transform: translateX(10px); }
.pf-tl-tip.left { transform: translateX(calc(-100% - 10px)); }
.pf-tl-tip-date { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); margin-bottom: 5px; }
.pf-tl-tip-big { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; }
.pf-tl-tip-rows { display: flex; flex-direction: column; gap: 5px; }
.pf-tl-tip-row { display: grid; grid-template-columns: 9px auto 1fr; align-items: center; gap: 8px; }
.pf-tl-tip-row .dot { width: 8px; height: 8px; border-radius: 2px; }
.pf-tl-tip-row .lbl { font-size: 11px; color: var(--muted); }
.pf-tl-tip-row .val { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 12px; color: var(--ink); text-align: right; letter-spacing: -0.01em; }

/* ── Demo mode ────────────────────────────────────────────────────────── */
.pf-demo-banner { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; padding: 11px 16px; margin-bottom: 18px; border: 1px solid var(--da-accent-border); border-radius: 6px; background: var(--da-accent-fill); }
.pf-demo-banner .tag { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--da-accent-ink); background: var(--da-accent); padding: 3px 8px; border-radius: 2px; }
.pf-demo-banner .msg { font-size: 12.5px; color: var(--ink-2); }
.pf-demo-banner .cta { display: inline-flex; align-items: center; gap: 6px; margin-left: auto; color: var(--da-accent); text-decoration: none; font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; }
.pf-demo-banner .cta svg { width: 13px; height: 13px; }
.con-main .pf-demo-banner { margin: 16px 32px 0; }
.pf-nav-signin { color: var(--ink-2); text-decoration: none; font-size: 13px; font-weight: 500; padding: 0 6px; }
.pf-nav-signin:hover { color: var(--ink); }
.pf-nav-cta { display: inline-flex; align-items: center; padding: 8px 14px; border-radius: 6px; background: var(--da-accent); color: var(--da-accent-ink); text-decoration: none; font-size: 12.5px; font-weight: 600; }
.pf-nav-cta:hover { background: var(--da-accent-2); }
.pf-demo-gate { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px; padding: 80px 24px; border: 1px dashed var(--line-2); border-radius: 10px; background: linear-gradient(180deg, var(--bg-2), transparent 70%); }
.pf-demo-gate .ic { width: 54px; height: 54px; border-radius: 14px; background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); color: var(--da-accent); display: inline-flex; align-items: center; justify-content: center; }
.pf-demo-gate .ic svg { width: 25px; height: 25px; }
.pf-demo-gate h3 { font-size: 22px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; margin: 6px 0 0; }
.pf-demo-gate p { font-size: 13.5px; color: var(--muted); line-height: 1.6; max-width: 52ch; margin: 0; }
.pf-demo-gate .acts { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; justify-content: center; margin-top: 8px; }
.pf-demo-gate .pf-btn-accent { text-decoration: none; min-height: 40px; padding: 11px 20px; }

/* ── Net worth timeline series toggles ────────────────────────────────── */
.pf-series { display: flex; align-items: center; gap: 14px; margin-top: 16px; flex-wrap: wrap; }
.pf-series-lbl { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600; }
.pf-series-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.pf-series-chip { display: inline-flex; align-items: center; gap: 7px; padding: 5px 11px; border-radius: 999px; border: 1px solid var(--line-2); background: transparent; color: var(--muted); font-family: inherit; font-size: 11px; font-weight: 500; cursor: pointer; transition: all .15s; }
.pf-series-chip .d { width: 8px; height: 8px; border-radius: 2px; }
.pf-series-chip:hover:not(:disabled) { color: var(--ink); border-color: var(--line-2); }
.pf-series-chip.on { color: var(--ink); border-color: var(--da-accent-border); background: var(--da-accent-fill); }
.pf-series-chip:disabled { opacity: 0.4; cursor: not-allowed; }
.pf-series-select { display: none; }

/* ── Cash section ─────────────────────────────────────────────────────── */
.pf-cash .pf-section-head { border-bottom: 1px solid var(--line-2); }
.pf-cash-tools { display: inline-flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.pf-liq-chip { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; border-radius: 2px; border: 1px solid var(--line-2); color: var(--muted); font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; }
.pf-liq-chip svg { width: 13px; height: 13px; color: var(--da-accent); }
.pf-sort { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.pf-sort select { padding: 6px 26px 6px 10px; border: 1px solid var(--line-2); border-radius: 3px; background: var(--surface); color: var(--ink); font-family: inherit; font-size: 12px; cursor: pointer; appearance: none; -webkit-appearance: none; color-scheme: dark;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%237c8597' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 9px center; }
.pf-cash-total { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 20px 0 24px; }
.pf-cash-total .l { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600; margin-bottom: 8px; }
.pf-cash-total .v { font-family: var(--font-mono); font-size: 40px; font-weight: 500; color: var(--ink); letter-spacing: -0.03em; line-height: 1; }
.pf-cash-total-sub { font-size: 12px; color: var(--muted-2); }
.pf-cash-grid { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, 1.3fr); gap: 22px; }
.pf-cash-list { display: flex; flex-direction: column; gap: 8px; align-content: start; }
.pf-cash-acct { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 15px 16px; border: 1px solid var(--line-2); border-radius: 4px; background: var(--surface); cursor: pointer; text-align: left; font-family: inherit; transition: border-color .15s, background .15s; }
.pf-cash-acct:hover { border-color: var(--line-2); background: var(--surface-2); }
.pf-cash-acct.sel { border-color: var(--da-accent-border); background: var(--da-accent-fill); }
.pf-cash-acct-main { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.pf-cash-acct-main .nm { font-size: 13.5px; font-weight: 600; color: var(--ink); }
.pf-cash-acct-main .ty { font-size: 10.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; }
.pf-cash-acct-val { text-align: right; display: flex; flex-direction: column; gap: 3px; }
.pf-cash-acct-val .bal { font-family: var(--font-mono); font-size: 14px; color: var(--ink); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }
.pf-cash-acct-val .chg { font-family: var(--font-mono); font-size: 11px; }
.pf-cash-acct-val .chg.pos { color: var(--pos); } .pf-cash-acct-val .chg.neg { color: var(--neg); } .pf-cash-acct-val .chg.zero { color: var(--muted-2); }
.pf-cash-add { display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 13px; border: 1px dashed var(--line-2); border-radius: 4px; background: transparent; color: var(--muted); font-family: inherit; font-size: 12px; font-weight: 500; cursor: pointer; transition: all .15s; }
.pf-cash-add:hover { border-color: var(--da-accent); color: var(--ink); }
.pf-cash-add svg { width: 14px; height: 14px; }
.pf-cash-detail { border: 1px solid var(--line-2); border-radius: 4px; background: var(--surface); padding: 20px; }
.pf-cash-detail-head { display: flex; align-items: flex-start; justify-content: space-between; }
.pf-cash-detail-head .nm { font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.pf-cash-detail-head .ty { font-size: 10.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 4px; }
.pf-cash-detail-bal { font-family: var(--font-mono); font-size: 32px; font-weight: 500; color: var(--ink); letter-spacing: -0.03em; margin-top: 14px; }
.pf-cash-spark { margin: 14px 0 6px; }
.pf-cash-hist { margin-top: 8px; }
.pf-cash-hist-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid var(--line-2); }
.pf-cash-hist-head span { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600; }
.pf-cash-hist-row { display: grid; grid-template-columns: 1fr auto auto; gap: 16px; padding: 11px 0; border-top: 1px solid var(--line); font-size: 12.5px; }
.pf-cash-hist-row:first-of-type { border-top: 0; }
.pf-cash-hist-row .d { color: var(--muted); }
.pf-cash-hist-row .v { font-family: var(--font-mono); color: var(--ink); font-variant-numeric: tabular-nums; text-align: right; }
.pf-cash-hist-row .df { font-family: var(--font-mono); font-variant-numeric: tabular-nums; text-align: right; min-width: 70px; }
.pf-cash-hist-row .df.pos { color: var(--pos); } .pf-cash-hist-row .df.neg { color: var(--neg); } .pf-cash-hist-row .df.zero { color: var(--muted-2); }

/* ── Section stub ─────────────────────────────────────────────────────── */
.pf-stub { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px; padding: 64px 24px; border: 1px dashed var(--line-2); border-radius: 4px; }
.pf-stub-ic { width: 44px; height: 44px; border-radius: 10px; background: var(--surface-hi); color: var(--muted); display: inline-flex; align-items: center; justify-content: center; }
.pf-stub-ic svg { width: 22px; height: 22px; }
.pf-stub-t { font-size: 16px; font-weight: 600; color: var(--ink); }
.pf-stub-d { font-size: 12.5px; color: var(--muted); max-width: 44ch; line-height: 1.55; }

/* ── Density ──────────────────────────────────────────────────────────── */
.density-compact .pf-section { margin-bottom: 30px; }
.density-compact .pf-quick-cell { padding: 14px 16px; }
.density-compact .pf-actcard { padding: 12px 14px; }
.density-comfy .pf-section { margin-bottom: 60px; }

/* ── Mobile ───────────────────────────────────────────────────────────── */
@media (max-width: 920px) {
  .pf-quick { grid-template-columns: repeat(2, 1fr); }
  .pf-quick-cell:nth-child(3) { border-left: 0; }
  .pf-quick-cell:nth-child(3), .pf-quick-cell:nth-child(4) { border-top: 1px solid var(--line-2); }
  .pf-trio { grid-template-columns: 1fr; gap: 32px; }
  .pf-cash-grid { grid-template-columns: 1fr; }
  .pf-risk-body { grid-template-columns: 1fr; justify-items: center; text-align: center; }
  .pf-risk-row { width: 100%; }
}
@media (max-width: 640px) {
  .pf-quick { grid-template-columns: 1fr; }
  .pf-quick-cell + .pf-quick-cell { border-left: 0; border-top: 1px solid var(--line-2); }
  .pf-series-chips { display: none; }
  .pf-series-select { display: inline-block; padding: 6px 26px 6px 10px; border: 1px solid var(--line-2); border-radius: 3px; background: var(--surface); color: var(--ink); font-family: inherit; font-size: 12px; appearance: none; -webkit-appearance: none; color-scheme: dark; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%237c8597' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 9px center; }
  .pf-div-stats { grid-template-columns: 1fr; }
  .pf-div-next { grid-template-columns: 1fr; gap: 8px; }
}


/* ════════════════════════════════════════════════════════════════
   ── from pf-cash.css ──
   ════════════════════════════════════════════════════════════════ */

/* ── Toolbar (headerless — section is already the active Cash tab) ─────── */
.pf-cash2-toolbar { display: flex; align-items: center; justify-content: flex-end; gap: 10px; flex-wrap: wrap; margin-bottom: 20px; }
.pf-cash2-toolbar .scr-sort { min-height: 36px; }
.pf-cash2-toolbar .scr-sort .label { padding: 0 11px; }
.pf-cash2-toolbar .scr-sort select { font-size: 12.5px; }
.pf-cash2-toolbar .pf-btn-ghost, .pf-cash2-toolbar .pf-btn-accent { min-height: 36px; }

/* ── Empty state ──────────────────────────────────────────────────────── */
.pf-cash2-empty { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 13px; padding: 76px 24px 84px; border: 1px dashed var(--line-2); border-radius: 10px; background: linear-gradient(180deg, var(--bg-2), transparent 70%); }
.pf-cash2-empty .ic { width: 56px; height: 56px; border-radius: 14px; background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); color: var(--da-accent); display: inline-flex; align-items: center; justify-content: center; }
.pf-cash2-empty .ic svg { width: 26px; height: 26px; }
.pf-cash2-empty h3 { font-size: 22px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; margin: 6px 0 0; }
.pf-cash2-empty p { font-size: 13.5px; color: var(--muted); line-height: 1.6; max-width: 52ch; margin: 0; }
.pf-cash2-empty .quickstart { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; margin-top: 10px; }
.pf-cash2-empty .quickstart .pf-btn-accent { min-height: 38px; padding: 10px 18px; }
.pf-cash2-empty .hint { display: inline-flex; align-items: center; gap: 8px; font-size: 11.5px; color: var(--muted-2); margin-top: 8px; }
.pf-cash2-empty .hint svg { width: 14px; height: 14px; color: var(--da-accent); flex-shrink: 0; }

/* ── Layout ───────────────────────────────────────────────────────────── */
.pf-cash2-grid { display: grid; grid-template-columns: 320px minmax(0, 1fr); gap: 22px; align-items: start; }

/* ── Left rail ────────────────────────────────────────────────────────── */
.pf-cash2-rail { display: flex; flex-direction: column; gap: 12px; position: sticky; top: 80px; align-self: start; max-height: calc(100vh - 96px); overflow-y: auto; scrollbar-width: thin; }
.pf-cash2-total { border: 1px solid var(--da-accent-border); border-radius: 8px; background: var(--da-accent-fill); padding: 18px 20px; }
.pf-cash2-total .lbl { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 600; }
.pf-cash2-total .val { font-family: var(--font-mono); font-size: 30px; font-weight: 500; color: var(--ink); letter-spacing: -0.03em; margin-top: 8px; font-variant-numeric: tabular-nums; }
.pf-cash2-total .val.neg { color: var(--neg); }
.pf-cash2-total .spark { height: 34px; margin: 10px 0 6px; }
.pf-cash2-total .meta { display: flex; align-items: center; gap: 12px; font-size: 11px; color: var(--muted-2); }
.pf-liq-chip.sm { padding: 3px 8px; font-size: 9px; }

.pf-cash2-list { display: flex; flex-direction: column; gap: 8px; }
.pf-cash2-acct { display: block; width: 100%; text-align: left; padding: 13px 15px; border: 1px solid var(--line-2); border-left: 2px solid var(--line-2); border-radius: 6px; background: var(--surface); cursor: pointer; font-family: inherit; transition: border-color .15s, background .15s; }
.pf-cash2-acct:hover { background: var(--surface-2); }
.pf-cash2-acct.sel { border-color: var(--da-accent-border); border-left-color: var(--da-accent); background: var(--da-accent-fill); }
.pf-cash2-acct .top { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.pf-cash2-acct .nm { font-size: 13.5px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-cash2-acct .bal { font-family: var(--font-mono); font-size: 13px; color: var(--ink); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; flex-shrink: 0; }
.pf-cash2-acct .bal.neg { color: var(--neg); }
.pf-cash2-acct .bar { height: 3px; border-radius: 999px; background: var(--surface-hi); overflow: hidden; margin: 9px 0 7px; }
.pf-cash2-acct .bar span { display: block; height: 100%; border-radius: 999px; background: var(--da-accent); }
.pf-cash2-acct.sel .bar { background: color-mix(in oklab, var(--da-accent) 22%, transparent); }
.pf-cash2-acct .bot { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.pf-cash2-acct .ty { font-size: 10.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-cash2-acct .sh { font-family: var(--font-mono); font-size: 10.5px; color: var(--muted-2); flex-shrink: 0; }
.pf-cash-add { display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 12px; border: 1px dashed var(--line-2); border-radius: 6px; background: transparent; color: var(--muted); font-family: inherit; font-size: 12px; font-weight: 500; cursor: pointer; transition: all .15s; }
.pf-cash-add:hover { border-color: var(--da-accent); color: var(--ink); }
.pf-cash-add svg { width: 14px; height: 14px; }

/* ── Detail pane ──────────────────────────────────────────────────────── */
.pf-cash2-detail { border: 1px solid var(--line-2); border-radius: 8px; background: var(--surface); padding: 22px 24px 24px; }
.pf-cash2-dhead { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding-bottom: 18px; border-bottom: 1px solid var(--line-2); }
.pf-cash2-dhead .nm { font-size: 19px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; display: flex; align-items: center; gap: 9px; flex-wrap: wrap; }
.pf-cash2-dhead .tag { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--da-accent); background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); padding: 2px 7px; border-radius: 2px; }
.pf-cash2-dhead .meta { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 6px; }
.pf-cash2-dhead .acts { display: inline-flex; align-items: center; gap: 8px; flex-shrink: 0; }

.pf-cash2-balrow { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; flex-wrap: wrap; padding: 20px 0 4px; }
.pf-cash2-balrow .bigbal .bl { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.14em; font-weight: 600; margin-bottom: 8px; }
.pf-cash2-balrow .bigbal .n { font-family: var(--font-mono); font-size: 40px; font-weight: 500; color: var(--ink); letter-spacing: -0.035em; line-height: 1; font-variant-numeric: tabular-nums; }
.pf-cash2-balrow .bigbal .n.neg { color: var(--neg); }
.pf-cash2-balrow .bigbal .conv { font-family: var(--font-mono); font-size: 13px; color: var(--muted-2); margin-top: 8px; }
.pf-cash2-balrow .since { text-align: right; }
.pf-cash2-balrow .since .d { font-family: var(--font-mono); font-size: 14px; font-weight: 500; display: block; }
.pf-cash2-balrow .since .l { font-size: 11px; color: var(--muted-2); }
.pf-cash2-balrow .since.pos .d { color: var(--pos); } .pf-cash2-balrow .since.neg .d { color: var(--neg); } .pf-cash2-balrow .since.zero .d { color: var(--muted); }

/* Chart */
.pf-acct-chart2 { margin: 14px 0 6px; }
.pf-acct-chart-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin-bottom: 8px; min-height: 30px; }
.pf-acct-chart-head .lbl { font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); }
.pf-acct-chart2 .pf-timeline { border: 0; background: transparent; padding: 0; }
.pf-acct-chart { margin: 14px 0 6px; }
.pf-acct-chart svg { display: block; width: 100%; height: 196px; }
.pf-acct-chart-empty { display: flex; align-items: center; gap: 10px; justify-content: center; height: 130px; margin: 14px 0; border: 1px dashed var(--line-2); border-radius: 6px; color: var(--muted); font-size: 12.5px; }
.pf-acct-chart-empty svg { width: 18px; height: 18px; color: var(--muted-2); }

/* Facts */
.pf-cash2-facts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: 6px; overflow: hidden; margin: 18px 0 22px; }
.pf-cash2-facts > div { background: var(--surface); padding: 13px 15px; display: flex; flex-direction: column; gap: 8px; }
.pf-cash2-facts .l { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.13em; font-weight: 600; }
.pf-cash2-facts .v { font-family: var(--font-mono); font-size: 14px; color: var(--ink); letter-spacing: -0.01em; }
.pf-cash2-facts .v.pos { color: var(--pos); } .pf-cash2-facts .v.neg { color: var(--neg); }

/* Composer */
.pf-cash2-composer { border: 1px solid var(--line-2); border-radius: 8px; background: var(--bg-2); padding: 16px 18px; }
.pf-cash2-composer .head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.pf-cash2-composer .head > span:first-child { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.13em; color: var(--ink-2); }
.pf-cash2-composer .head .hint { font-size: 11.5px; color: var(--muted-2); font-weight: 400; text-transform: none; letter-spacing: 0; }
.pf-cash2-composer .row { display: grid; grid-template-columns: 150px 180px 1fr auto; gap: 10px; align-items: center; }
.pf-cash2-composer .row .pf-input { padding-top: 9px; padding-bottom: 9px; }
.pf-cash2-composer .pf-btn-accent { white-space: nowrap; }
.pf-cash2-composer .quick { display: flex; gap: 18px; margin-top: 13px; }
.pf-cash2-composer .quick .pf-inline-link svg { width: 14px; height: 14px; }

/* History */
.pf-cash2-hist { margin-top: 22px; }
.pf-cash2-hist .hh { display: flex; align-items: center; font-size: 10px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.16em; color: var(--muted); padding-bottom: 8px; }
.pf-cash2-hist .hh span { color: var(--muted-2); }
.pf-cash2-hist .hh .pf-inline-link { margin-left: auto; }
.pf-cash2-hrow { display: grid; grid-template-columns: 150px 120px 84px 1fr auto; align-items: center; gap: 12px; padding: 11px 8px; border-top: 1px solid var(--line); border-radius: 6px; }
.pf-cash2-hrow:hover { background: var(--bg-2); }
.pf-cash2-hrow.editing { background: var(--da-accent-fill); }
.pf-cash2-hrow .d { font-size: 12.5px; color: var(--ink-2); display: flex; align-items: center; gap: 8px; }
.pf-cash2-hrow .d em { font-style: normal; font-size: 8.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--da-accent); background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); padding: 1px 5px; border-radius: 2px; }
.pf-cash2-hrow .v { font-family: var(--font-mono); font-size: 13px; color: var(--ink); font-variant-numeric: tabular-nums; }
.pf-cash2-hrow .df { font-family: var(--font-mono); font-size: 11.5px; }
.pf-cash2-hrow .df.pos { color: var(--pos); } .pf-cash2-hrow .df.neg { color: var(--neg); } .pf-cash2-hrow .df.zero { color: var(--muted-2); }
.pf-cash2-hrow .nt { font-size: 12px; color: var(--muted); font-style: italic; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-cash2-hrow .act { display: inline-flex; gap: 5px; opacity: 0; transition: opacity .12s; }
.pf-cash2-hrow:hover .act, .pf-cash2-hrow.editing .act { opacity: 1; }

.pf-iconbtn-sm { width: 30px; height: 30px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 1px solid var(--line-2); color: var(--muted); cursor: pointer; transition: all .14s; }
.pf-iconbtn-sm:hover { color: var(--ink); border-color: var(--line-2); background: var(--surface-2); }
.pf-iconbtn-sm svg { width: 15px; height: 15px; }
.pf-iconbtn-sm.danger:hover { color: var(--neg); border-color: var(--neg-border); background: var(--neg-fill); }

/* Row "more" menu */
.pf-rowmenu { position: relative; display: inline-flex; }
.pf-rowmenu-pop { position: absolute; right: 0; top: calc(100% + 6px); z-index: 40; min-width: 168px; padding: 6px; border: 1px solid var(--line-2); border-radius: 8px; background: var(--surface); box-shadow: 0 14px 40px rgba(0,0,0,0.45); display: flex; flex-direction: column; gap: 2px; }
.pf-rowmenu-pop button { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border: 0; border-radius: 5px; background: transparent; color: var(--ink-2); font-family: inherit; font-size: 12.5px; font-weight: 500; cursor: pointer; text-align: left; }
.pf-rowmenu-pop button:hover { background: var(--surface-2); color: var(--ink); }
.pf-rowmenu-pop button.danger { color: var(--neg); }
.pf-rowmenu-pop button.danger:hover { background: var(--neg-fill); }
.pf-rowmenu-pop button svg { width: 14px; height: 14px; }

/* ── Modal ────────────────────────────────────────────────────────────── */
.pf-modal-overlay { position: fixed; inset: 0; z-index: 200; background: rgba(4,8,14,0.66); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); display: flex; align-items: center; justify-content: center; padding: 24px 20px; overflow-y: auto; }
.pf-modal { width: 100%; max-width: 460px; max-height: calc(100vh - 48px); display: flex; flex-direction: column; background: var(--surface); border: 1px solid var(--line-2); border-radius: 12px; box-shadow: 0 28px 90px rgba(0,0,0,0.55); opacity: 1; animation: pf-modal-in .18s ease-out; }
.pf-modal.wide { max-width: 580px; }
@keyframes pf-modal-in { from { transform: translateY(10px) scale(0.99); } to { transform: none; } }
.pf-modal-head { flex-shrink: 0; display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 20px 22px 16px; border-bottom: 1px solid var(--line-2); }
.pf-modal-title { font-size: 18px; font-weight: 600; color: var(--ink); letter-spacing: -0.015em; }
.pf-modal-sub { font-size: 12px; color: var(--muted); margin-top: 4px; font-family: var(--font-mono); letter-spacing: -0.01em; }
.pf-modal-x { width: 30px; height: 30px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: var(--muted); cursor: pointer; }
.pf-modal-x:hover { background: var(--surface-2); color: var(--ink); }
.pf-modal-x svg { width: 17px; height: 17px; }
.pf-modal-body { flex: 1 1 auto; overflow-y: auto; padding: 20px 22px; display: flex; flex-direction: column; gap: 15px; }
.pf-modal-foot { flex-shrink: 0; display: flex; align-items: center; justify-content: flex-end; gap: 10px; padding: 15px 22px; border-top: 1px solid var(--line-2); }
.pf-modal-hint { display: flex; gap: 9px; align-items: flex-start; font-size: 11.5px; color: var(--muted); line-height: 1.5; margin: 2px 0 0; }
.pf-modal-hint b { color: var(--ink-2); font-weight: 600; }
.pf-modal-hint svg { width: 14px; height: 14px; color: var(--da-accent); flex-shrink: 0; margin-top: 1px; }

/* ── Form fields ──────────────────────────────────────────────────────── */
.pf-field { display: flex; flex-direction: column; gap: 7px; }
.pf-field-label { font-size: 11px; font-weight: 600; color: var(--ink-2); text-transform: uppercase; letter-spacing: 0.1em; }
.pf-field-label i { color: var(--da-accent); font-style: normal; }
.pf-field-hint { font-size: 11px; color: var(--muted-2); font-family: var(--font-mono); }
.pf-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
/* Scoped under .pf-page so the v6 inputs beat the global bare-element rules
   in inputs.css (input[type=number]/[type=date]/select have specificity 0,1,1
   and would otherwise override the .pf-input class). */
.pf-page .pf-input { width: 100%; padding: 10px 12px; font-family: inherit; font-size: 13.5px; color: var(--ink); background: var(--bg-2); border: 1px solid var(--line-2); border-radius: 6px; outline: none; transition: border-color .15s, box-shadow .15s; color-scheme: dark; box-sizing: border-box; }
.pf-page .pf-input::placeholder { color: var(--faint); }
.pf-page .pf-input:focus { border-color: var(--da-accent); box-shadow: 0 0 0 3px var(--da-accent-fill); }
.pf-page .pf-textarea { resize: vertical; min-height: 64px; line-height: 1.5; }
.pf-page .pf-select { appearance: none; -webkit-appearance: none; padding-right: 32px; cursor: pointer; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%237c8597' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 11px center; }
.pf-input-money { position: relative; display: flex; align-items: center; }
.pf-input-money .cur { position: absolute; left: 12px; font-family: var(--font-mono); font-size: 12px; color: var(--muted); pointer-events: none; }
.pf-input-money .pf-input { padding-left: 46px; }

/* Boolean flags as toggle switches in a hairline list (not boxed inputs) */
.pf-flags { display: flex; flex-direction: column; border-top: 1px solid var(--line); }
.pf-flagrow { display: flex; align-items: center; justify-content: space-between; gap: 18px; padding: 13px 2px; border-bottom: 1px solid var(--line); }
.pf-flagrow .t { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.pf-flagrow .lbl { font-size: 13.5px; font-weight: 500; color: var(--ink); }
.pf-flagrow .sub { font-size: 11.5px; color: var(--muted); line-height: 1.4; }
.pf-switch { position: relative; width: 42px; height: 24px; flex-shrink: 0; padding: 0; border: 1px solid var(--line-2); border-radius: 999px; background: var(--surface-hi); cursor: pointer; }
.pf-switch.on { background: var(--da-accent); border-color: var(--da-accent); }
.pf-switch .knob { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 999px; background: var(--muted); transition: transform .16s ease, background .16s ease; }
.pf-switch.on .knob { transform: translateX(18px); background: var(--da-accent-ink); }
.pf-switch:focus-visible { outline: 2px solid var(--da-accent); outline-offset: 2px; }

.pf-btn-danger { display: inline-flex; align-items: center; gap: 7px; padding: 9px 14px; border-radius: 6px; cursor: pointer; font-family: inherit; font-size: 12px; font-weight: 600; background: var(--neg); border: 0; color: #2a0b0b; }
.pf-btn-danger:hover { filter: brightness(1.08); }
.pf-btn-accent:disabled, .pf-btn-ghost:disabled { opacity: 0.45; cursor: not-allowed; }
.pf-confirm-msg { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; margin: 0; }
.pf-confirm-msg b { color: var(--ink); }

/* ── Toast ────────────────────────────────────────────────────────────── */
.pf-toast { position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%); z-index: 240; display: inline-flex; align-items: center; gap: 8px; padding: 11px 18px; border-radius: 8px; background: var(--pos-fill); border: 1px solid var(--pos-border); color: var(--pos); font-size: 12.5px; font-weight: 600; box-shadow: 0 14px 40px rgba(0,0,0,0.4); }
.pf-toast svg { width: 15px; height: 15px; }

/* ── Responsive ───────────────────────────────────────────────────────── */
@media (max-width: 1080px) {
  .pf-cash2-grid { grid-template-columns: 1fr; }
  .pf-cash2-rail { display: grid; grid-template-columns: 280px 1fr; gap: 16px; align-items: start; position: static; max-height: none; overflow: visible; }
  .pf-cash2-total { grid-column: 1; }
  .pf-cash2-list { grid-column: 2; }
}
@media (max-width: 720px) {
  .pf-cash2-rail { grid-template-columns: 1fr; }
  .pf-cash2-list { grid-column: 1; }
  .pf-cash2-composer .row { grid-template-columns: 1fr 1fr; }
  .pf-cash2-composer .row .pf-input-money, .pf-cash2-composer .row > .pf-input:nth-child(3) { grid-column: span 2; }
  .pf-cash2-composer .row .pf-btn-accent { grid-column: span 2; }
  .pf-cash2-facts { grid-template-columns: repeat(2, 1fr); }
  .pf-field-row { grid-template-columns: 1fr; }
  .pf-cash2-hrow { grid-template-columns: 1fr auto auto; grid-template-areas: "d v act" "nt nt act"; row-gap: 4px; }
  .pf-cash2-hrow .d { grid-area: d; } .pf-cash2-hrow .v { grid-area: v; text-align: right; } .pf-cash2-hrow .df { display: none; } .pf-cash2-hrow .nt { grid-area: nt; white-space: normal; } .pf-cash2-hrow .act { grid-area: act; opacity: 1; }
}


/* ════════════════════════════════════════════════════════════════
   ── from pf-triage.css ── Direction B · Triage two-column overview
   ════════════════════════════════════════════════════════════════ */

.tri-cols { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: 40px; margin-top: 8px; }
.tri-col { min-width: 0; display: flex; flex-direction: column; gap: 36px; }
.tri-coltitle { display: flex; align-items: baseline; gap: 12px; padding-bottom: 14px; margin-bottom: 4px; border-bottom: 1px solid var(--line-2); }
.tri-coltitle .t { font-size: 14px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.tri-coltitle .h { font-size: 11px; color: var(--muted-2); text-transform: uppercase; letter-spacing: 0.12em; }

/* Right column: a quiet rail surface so attention reads as "the inbox" */
.tri-col.attention { background: var(--bg-2); border: 1px solid var(--line); border-radius: 6px; padding: 24px; gap: 30px; }
.tri-col.attention .tri-coltitle { border-color: var(--line-2); }

/* Sub-sections inside a column don't need the big section margin */
.tri-col .pf-section { margin-bottom: 0; }
.tri-col .pf-two { gap: 28px; }

/* Compact hero for triage: number left, triplet right, on one band */
.tri-hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); gap: 40px; align-items: center; padding-bottom: 32px; margin-bottom: 32px; border-bottom: 1px solid var(--line-2); }
.tri-hero-l .lbl { font-family: var(--font-mono); font-size: 12px; color: var(--muted); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 8px; }
.tri-hero-l .big { font-family: var(--font-mono); font-size: 76px; font-weight: 500; letter-spacing: -0.045em; line-height: 0.92; color: var(--ink); font-variant-numeric: tabular-nums; }
.tri-hero-l .big .cur { color: var(--muted-2); font-size: 28px; margin-right: 10px; }
.tri-hero-l .sub { margin-top: 18px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; font-size: 12.5px; color: var(--muted); }

@media (max-width: 1100px) {
  .tri-cols { grid-template-columns: 1fr; gap: 40px; }
  .tri-hero { grid-template-columns: 1fr; gap: 28px; }
  .tri-hero-l .big { font-size: 60px; }
}
@media (max-width: 640px) {
  .tri-col.attention { padding: 18px; }
  .tri-hero-l .big { font-size: 48px; }
}

/* ════════════════════════════════════════════════════════════════
   WIDTH — the v6 page owns a 1320px column. The legacy
   .portfolio-container (layout.css) clamps to 900px, which squeezes
   the redesign and causes overflows. When the v6 page is present,
   widen the container and let .pf-page span it (gutters on the
   container, like the dashboard's .o2 column).
   ════════════════════════════════════════════════════════════════ */
.portfolio-container:has(.pf-page) {
  max-width: 1320px;
  padding-left: 32px;
  padding-right: 32px;
}
.portfolio-container:has(.pf-page) .pf-page {
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}
@media (max-width: 680px) {
  .portfolio-container:has(.pf-page) { padding-left: 16px; padding-right: 16px; }
}

/* ════════════════════════════════════════════════════════════════
   REVIEW FIXES
   ════════════════════════════════════════════════════════════════ */

/* (3) Dividend stat cells: pin the value to the bottom so a label that
   wraps to two lines does not push its value out of alignment. */
.pf-div-stat { display: flex; flex-direction: column; }
.pf-div-stat .v { margin-top: auto; }

/* (5) Breathing room above the premium "Deeper analysis" trio. */
.pf-deeper { margin-top: 24px; padding-top: 36px; border-top: 1px solid var(--line); }

/* (4/7) Lock the account chart block to a constant height so selecting an
   account with <2 entries (or while history loads) does not jump the pane.
   Head (30) + body (196) are fixed for both the real chart and the empty
   state. */
.pf-acct-chart2 { min-height: 234px; }
.pf-acct-chart2 .pf-acct-chart-head { height: 30px; margin-bottom: 8px; min-height: 0; }
.pf-acct-chart2 .pf-acct-chart-empty { height: 196px; margin: 0; }
.pf-acct-chart2 .pf-timeline { margin: 0; }
.pf-acct-chart2 .pf-timeline svg { height: 196px; }

/* ════════════════════════════════════════════════════════════════
   IMPORT MODAL — v6 restyle of the shared ImportModal, scoped to the
   portfolio page so the rest of the app's modals are untouched. The
   import logic (shared/Modal + import-* steps) is reused as-is; only
   presentation is mapped onto the v6 idiom.
   ════════════════════════════════════════════════════════════════ */

/* Shell */
.pf-page .modal-overlay { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; background: rgba(4, 8, 14, 0.66); backdrop-filter: blur(3px); -webkit-backdrop-filter: blur(3px); }
.pf-page .modal-content { width: 100%; max-width: 600px; max-height: calc(100vh - 64px); overflow-y: auto; background: var(--surface); border: 1px solid var(--line-2); border-radius: 12px; box-shadow: 0 18px 40px rgba(0, 0, 0, 0.55); padding: 22px 24px 24px; color: var(--ink); }
.pf-page .modal-content.modal-large, .pf-page .modal-content.modal-xlarge { max-width: 760px; }
.pf-page .modal-content > h3 { margin: 0 0 14px; font-size: 17px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.pf-page .modal-content .modal-subtitle { margin: -10px 0 16px; font-family: var(--font-mono); font-size: 12px; color: var(--muted); }
.pf-page .modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 22px; padding-top: 16px; border-top: 1px solid var(--line); }

/* Buttons inside the import modal map to the v6 button styles */
.pf-page .modal-content .btn-primary { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; border: 0; border-radius: 6px; cursor: pointer; background: var(--da-accent); color: var(--da-accent-ink); }
.pf-page .modal-content .btn-primary:hover { background: var(--da-accent-2); }
.pf-page .modal-content .btn-primary:disabled { opacity: 0.5; cursor: not-allowed; }
.pf-page .modal-content .btn-secondary { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; border: 1px solid var(--line-2); border-radius: 6px; cursor: pointer; background: transparent; color: var(--ink-2); }
.pf-page .modal-content .btn-secondary:hover { background: var(--bg-2); border-color: var(--muted-2); }

/* Bare inputs/selects in the import steps adopt the v6 field look */
.pf-page .modal-content input, .pf-page .modal-content select, .pf-page .modal-content textarea { font-family: inherit; font-size: 13.5px; color: var(--ink); background: var(--bg-2); border: 1px solid var(--line-2); border-radius: 6px; padding: 9px 11px; outline: none; box-sizing: border-box; transition: border-color .15s, box-shadow .15s; color-scheme: dark; }
.pf-page .modal-content input:focus, .pf-page .modal-content select:focus, .pf-page .modal-content textarea:focus { border-color: var(--da-accent); box-shadow: 0 0 0 3px var(--da-accent-fill); }

/* Upload step */
.pf-page .import-dropzone { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; text-align: center; padding: 44px 24px; border: 1.5px dashed var(--line-2); border-radius: 10px; background: var(--bg-2); cursor: pointer; transition: border-color .15s, background .15s; }
.pf-page .import-dropzone-active { border-color: var(--da-accent); background: var(--da-accent-fill); }
.pf-page .import-dropzone-icon { width: 52px; height: 52px; border-radius: 13px; background: var(--surface); border: 1px solid var(--line-2); color: var(--da-accent); display: inline-flex; align-items: center; justify-content: center; }
.pf-page .import-dropzone-text { font-size: 15px; font-weight: 600; color: var(--ink); margin: 0; }
.pf-page .import-dropzone-or { font-size: 12px; color: var(--muted-2); margin: 0; }
.pf-page .import-dropzone-formats { font-size: 11px; color: var(--muted-2); font-family: var(--font-mono); margin: 4px 0 0; }
.pf-page .import-spinner { animation: pf-spin 1s linear infinite; }
@keyframes pf-spin { to { transform: rotate(360deg); } }

/* File bar + map step */
.pf-page .import-file-info { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; padding: 12px 14px; margin-bottom: 16px; border: 1px solid var(--line-2); border-radius: 8px; background: var(--bg-2); }
.pf-page .import-file-name { flex: 1; min-width: 0; font-family: var(--font-mono); font-size: 12px; color: var(--ink-2); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-page .import-header-row-input { width: 70px; }
.pf-page .import-mapping-section { margin-top: 16px; }
.pf-page .import-mapping-grid { display: flex; flex-direction: column; gap: 9px; }
.pf-page .import-mapping-row { display: grid; grid-template-columns: 160px 1fr; align-items: center; gap: 14px; }
.pf-page .import-mapping-label { font-size: 12.5px; color: var(--ink-2); font-weight: 500; }
.pf-page .import-required { color: var(--neg); font-style: normal; }
.pf-page .import-mapping-hint { font-size: 11.5px; color: var(--muted); margin-top: 6px; }

/* Validation summary + preview */
.pf-page .import-validation-summary { display: flex; align-items: center; gap: 14px; font-size: 12px; font-weight: 600; padding: 14px 0 8px; }
.pf-page .import-valid-count, .pf-page .import-status-valid { color: var(--pos); }
.pf-page .import-invalid-count, .pf-page .import-status-invalid { color: var(--neg); }
.pf-page .import-total-count { margin-left: auto; color: var(--muted-2); font-weight: 500; }
.pf-page .import-entries-list { display: flex; flex-direction: column; border: 1px solid var(--line-2); border-radius: 8px; overflow: hidden; }
.pf-page .import-entry-row { display: flex; align-items: center; gap: 12px; padding: 9px 12px; border-bottom: 1px solid var(--line); font-size: 12px; font-family: var(--font-mono); color: var(--ink-2); }
.pf-page .import-entry-row:last-child { border-bottom: 0; }
.pf-page .import-edit-input { padding: 5px 8px; font-size: 12px; }

/* Progress + complete */
.pf-page .import-progress-bar { height: 8px; border-radius: 999px; background: var(--surface-hi); overflow: hidden; margin: 14px 0 8px; }
.pf-page .import-progress-fill { height: 100%; background: var(--da-accent); transition: width .2s; }
.pf-page .import-progress-text { font-size: 12px; color: var(--muted); text-align: center; }
.pf-page .import-complete-step { text-align: center; padding: 12px 0; }
.pf-page .import-results-icon { color: var(--pos); margin-bottom: 8px; }
.pf-page .import-results-title { font-size: 15px; font-weight: 600; color: var(--ink); }
.pf-page .import-result-success { color: var(--pos); }
.pf-page .import-result-failure { color: var(--neg); }

/* Errors */
.pf-page .import-error { color: var(--neg); font-size: 12.5px; margin-top: 10px; }
.pf-page .import-errors-list { margin-top: 8px; font-size: 12px; color: var(--neg-2, var(--neg)); }
.pf-page .import-errors-more { font-size: 11.5px; color: var(--muted-2); margin-top: 4px; }

@media (max-width: 640px) {
  .pf-page .import-mapping-row { grid-template-columns: 1fr; gap: 6px; }
}

/* The add/edit form wraps all fields, so .pf-modal-body's gap (which only
   spaces the body's direct children) doesn't separate them. Make the form a
   flex column so consecutive fields get proper vertical spacing. */
.pf-modal-body form { display: flex; flex-direction: column; gap: 18px; }

/* ════════════════════════════════════════════════════════════════
   LOADING SKELETON — a shimmering placeholder of the portfolio layout
   shown while auth resolves and data loads. Used by portfolio.astro
   (#loading) and the React loading states (PfSkeleton).
   ════════════════════════════════════════════════════════════════ */
@keyframes pf-sk-shimmer { to { background-position-x: -200%; } }
.pf-sk {
  display: block; border-radius: 6px;
  background: linear-gradient(90deg, var(--surface) 25%, var(--surface-hi) 37%, var(--surface) 63%);
  background-size: 200% 100%;
  animation: pf-sk-shimmer 1.4s ease-in-out infinite;
}
@media (prefers-reduced-motion: reduce) { .pf-sk { animation: none; } }

.pf-skel { padding-top: 4px; }
.pf-skel-eyebrow { width: 230px; height: 13px; margin-bottom: 26px; }
.pf-skel-tabs { display: flex; gap: 26px; padding-bottom: 16px; border-bottom: 1px solid var(--line-2); margin-bottom: 36px; }
.pf-skel-tab { width: 64px; height: 15px; flex-shrink: 0; }
.pf-skel-hero { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); gap: 40px; align-items: center; padding-bottom: 32px; margin-bottom: 32px; border-bottom: 1px solid var(--line-2); }
.pf-skel-hero .lbl { width: 150px; height: 12px; }
.pf-skel-hero .big { width: 300px; height: 60px; margin: 14px 0; border-radius: 8px; }
.pf-skel-hero .sub { width: 240px; height: 12px; }
.pf-skel-perf { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.pf-skel-perf .cell { height: 84px; border-radius: 3px; }
.pf-skel-snap { height: 54px; margin-bottom: 36px; border-radius: 6px; }
.pf-skel-timeline { height: 280px; margin-bottom: 48px; border-radius: 3px; }
.pf-skel-cols { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(0, 1fr); gap: 48px; }
.pf-skel-card { border-radius: 3px; }
.pf-skel-card.tall { height: 230px; }
.pf-skel-card.med { height: 150px; margin-top: 24px; }
@media (max-width: 1100px) {
  .pf-skel-hero { grid-template-columns: 1fr; }
  .pf-skel-cols { grid-template-columns: 1fr; gap: 36px; }
}

/* Account workspace loading skeleton (rail + detail) */
.pf-skel-ws { display: grid; grid-template-columns: 320px 1fr; gap: 28px; }
.pf-skel-ws .rail { height: 340px; border-radius: 8px; }
.pf-skel-ws .detail { height: 480px; border-radius: 8px; }
@media (max-width: 1080px) { .pf-skel-ws { grid-template-columns: 1fr; } }

/* ─────────────────────────────────────────────────────────────────────────
   Position-based sections (Investments / Crypto) — v6 detail pane: account
   totals, value-trend chart, position cards, transaction history, savings
   plans. Ported from the design handover (pf-invest.css), scoped to .pf-page.
   ───────────────────────────────────────────────────────────────────────── */

/* Account value-over-time chart */
.pf-page .inv-chart { margin: 4px 0 24px; padding: 16px 18px; border: 1px solid var(--line-2); border-radius: 8px; background: var(--surface); }
.pf-page .inv-chart-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 10px; min-height: 32px; }
.pf-page .inv-chart-title { display: inline-flex; align-items: center; gap: 10px; font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--da-accent); }
.pf-page .inv-chart .pf-timeline { border: 0; background: transparent; padding: 0; }

/* Savings plans */
.pf-page .inv-plan-badge { display: inline-flex; align-items: center; gap: 4px; font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--da-accent); background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); padding: 1px 6px; border-radius: 2px; }
.pf-page .inv-plan-badge svg { width: 10px; height: 10px; }
.pf-page .pf-iconbtn-sm.on { color: var(--da-accent); border-color: var(--da-accent-border); background: var(--da-accent-fill); }
.pf-page .sp-banner { display: grid; grid-template-columns: 36px 1fr auto; align-items: center; gap: 14px; padding: 14px 16px; margin-bottom: 18px; border: 1px solid var(--da-accent-border); border-radius: 8px; background: var(--da-accent-fill); }
.pf-page .sp-banner .ic { width: 36px; height: 36px; border-radius: 8px; display: inline-flex; align-items: center; justify-content: center; background: var(--surface); color: var(--da-accent); border: 1px solid var(--da-accent-border); }
.pf-page .sp-banner .ic svg { width: 18px; height: 18px; }
.pf-page .sp-banner .t { display: block; font-size: 13.5px; font-weight: 600; color: var(--ink); }
.pf-page .sp-banner .d { display: block; font-size: 11.5px; color: var(--muted); margin-top: 2px; }
.pf-page .sp-notes { border: 1px solid var(--da-accent-border); border-radius: 8px; background: var(--da-accent-fill); padding: 14px 16px; }
.pf-page .sp-notes-h { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--da-accent); margin-bottom: 10px; }
.pf-page .sp-notes-h svg { width: 14px; height: 14px; }
.pf-page .sp-notes ul { margin: 0; padding-left: 18px; display: flex; flex-direction: column; gap: 6px; }
.pf-page .sp-notes li { font-size: 12px; color: var(--ink-2); line-height: 1.45; }
.pf-page .sp-review { display: flex; flex-direction: column; gap: 12px; }
.pf-page .sp-rev-row { border: 1px solid var(--line-2); border-radius: 8px; background: var(--bg-2); padding: 14px 16px; }
.pf-page .sp-rev-top { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.pf-page .sp-rev-top .sym { font-size: 14px; font-weight: 600; color: var(--ink); }
.pf-page .sp-rev-top .est { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; color: var(--amber); background: rgba(255,198,109,0.12); border: 1px solid rgba(255,198,109,0.3); padding: 2px 7px; border-radius: 2px; }
.pf-page .sp-rev-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.pf-page .sp-rev-f { display: flex; flex-direction: column; gap: 6px; }
.pf-page .sp-rev-f span { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.pf-page .sp-rev-act { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.pf-page .sp-rev-total { font-family: var(--font-mono); font-size: 13px; color: var(--ink); margin-right: auto; }
.pf-page .pf-btn-ghost.danger { color: var(--neg); border-color: var(--neg-border); }
.pf-page .pf-btn-ghost.danger:hover { background: var(--neg-fill); }
.pf-page .sp-review-empty { display: flex; align-items: center; gap: 12px; padding: 22px; font-size: 13px; color: var(--muted); }
.pf-page .sp-review-empty svg { width: 20px; height: 20px; color: var(--pos); flex-shrink: 0; }
@media (max-width: 640px) { .pf-page .sp-rev-grid { grid-template-columns: 1fr; } .pf-page .sp-rev-act { flex-wrap: wrap; } }

/* Simple-mode composer with cost basis + history cost chip */
.pf-page .pf-cash2-composer .row.inv-simple-row { grid-template-columns: 130px 1fr 1fr 1fr auto; }
.pf-page .inv-cost-chip { display: inline-block; font-family: var(--font-mono); font-size: 10.5px; color: var(--muted-2); background: var(--surface-hi); border: 1px solid var(--line-2); border-radius: 3px; padding: 1px 6px; margin-right: 8px; font-style: normal; }
@media (max-width: 720px) {
  .pf-page .pf-cash2-composer .row.inv-simple-row { grid-template-columns: 1fr 1fr; }
  .pf-page .pf-cash2-composer .row.inv-simple-row > * { grid-column: span 1; }
  .pf-page .pf-cash2-composer .row.inv-simple-row .pf-btn-accent { grid-column: span 2; }
}

/* Mode badge in detail header */
.pf-page .inv-mode { font-size: 9px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.1em; padding: 2px 7px; border-radius: 2px; margin-left: 10px; vertical-align: middle; }
.pf-page .inv-mode.detailed { color: var(--da-accent); background: var(--da-accent-fill); border: 1px solid var(--da-accent-border); }
.pf-page .inv-mode.simple { color: var(--muted); background: var(--surface-hi); border: 1px solid var(--line-2); }
.pf-page .inv-total-gain { font-family: var(--font-mono); font-size: 12px; margin: 6px 0 8px; }
.pf-page .inv-total-gain .pos { color: var(--pos); } .pf-page .inv-total-gain .neg { color: var(--neg); } .pf-page .inv-total-gain .zero { color: var(--muted-2); }
.pf-page .pf-cash2-acct .sh.pos { color: var(--pos); } .pf-page .pf-cash2-acct .sh.neg { color: var(--neg); }

/* Mode toggle (Add Investment Account) */
.pf-page .inv-modeseg { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.pf-page .inv-modeseg button { display: flex; flex-direction: column; gap: 3px; align-items: flex-start; padding: 11px 14px; border: 1px solid var(--line-2); border-radius: 6px; background: var(--bg-2); color: var(--ink-2); font-family: inherit; font-size: 13px; font-weight: 600; cursor: pointer; }
.pf-page .inv-modeseg button span { font-size: 10.5px; font-weight: 400; color: var(--muted); text-transform: none; letter-spacing: 0; }
.pf-page .inv-modeseg button.on { border-color: var(--da-accent-border); background: var(--da-accent-fill); color: var(--ink); }

/* Account totals row (detailed) */
.pf-page .inv-totals { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: 6px; overflow: hidden; margin: 20px 0 22px; }
.pf-page .inv-totals > div { background: var(--surface); padding: 14px 16px; display: flex; flex-direction: column; gap: 6px; }
.pf-page .inv-totals .l { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.13em; font-weight: 600; }
.pf-page .inv-totals .v { font-family: var(--font-mono); font-size: 18px; color: var(--ink); letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.pf-page .inv-totals .v.pos { color: var(--pos); } .pf-page .inv-totals .v.neg { color: var(--neg); }
.pf-page .inv-totals .sub { font-family: var(--font-mono); font-size: 11px; color: var(--muted-2); }

/* Positions */
.pf-page .inv-pos-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-bottom: 14px; border-bottom: 1px solid var(--line-2); }
.pf-page .inv-pos-head h3 { font-size: 14px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; margin: 0; }
.pf-page .inv-pos-head h3 span { color: var(--muted-2); font-weight: 500; }
.pf-page .inv-pos-tools { display: inline-flex; align-items: center; gap: 14px; }
.pf-page .inv-pos-list { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.pf-page .inv-pos { display: grid; grid-template-columns: minmax(0, 1fr) auto auto; align-items: center; gap: 16px; padding: 15px 16px; border: 1px solid var(--line-2); border-radius: 6px; background: var(--surface); transition: border-color .15s, background .15s; }
.pf-page .inv-pos:hover { border-color: var(--line-2); background: var(--surface-2); }
.pf-page .inv-pos-main { min-width: 0; }
.pf-page .inv-pos-id { display: flex; align-items: baseline; gap: 9px; }
.pf-page .inv-pos-id .sym { font-size: 14.5px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.pf-page .inv-pos-id .nm { font-size: 12px; color: var(--muted); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-page .inv-pos-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 7px 0; }
.pf-page .inv-tag { font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 3px; letter-spacing: 0.01em; }
.pf-page .inv-tag.accent { color: var(--da-accent); background: var(--da-accent-fill); }
.pf-page .inv-tag.pos { color: var(--pos); background: var(--pos-fill); }
.pf-page .inv-tag.violet { color: var(--violet); background: color-mix(in oklab, var(--violet) 14%, transparent); }
.pf-page .inv-tag.amber { color: var(--amber); background: rgba(255,198,109,0.12); }
.pf-page .inv-pos-sub { font-family: var(--font-mono); font-size: 11.5px; color: var(--muted-2); }
.pf-page .inv-pos-val { text-align: right; }
.pf-page .inv-pos-val .v { font-family: var(--font-mono); font-size: 15px; color: var(--ink); font-variant-numeric: tabular-nums; letter-spacing: -0.01em; }
.pf-page .inv-pos-val .conv { font-family: var(--font-mono); font-size: 11px; color: var(--muted-2); margin-top: 3px; }
.pf-page .inv-pos-val .gain { font-family: var(--font-mono); font-size: 11.5px; margin-top: 3px; }
.pf-page .inv-pos-val .gain.pos { color: var(--pos); } .pf-page .inv-pos-val .gain.neg { color: var(--neg); } .pf-page .inv-pos-val .gain.zero { color: var(--muted-2); }
.pf-page .inv-pos-act { display: inline-flex; align-items: center; gap: 6px; }
.pf-page .inv-pos-empty { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 11px; padding: 48px 24px; border: 1px dashed var(--line-2); border-radius: 6px; }
.pf-page .inv-pos-empty .ic { width: 42px; height: 42px; border-radius: 10px; background: var(--surface-hi); color: var(--muted); display: inline-flex; align-items: center; justify-content: center; }
.pf-page .inv-pos-empty .ic svg { width: 21px; height: 21px; }
.pf-page .inv-pos-empty .t { font-size: 15px; font-weight: 600; color: var(--ink); }
.pf-page .inv-pos-empty .d { font-size: 12.5px; color: var(--muted); max-width: 42ch; line-height: 1.5; }

/* Ticker search */
.pf-page .inv-searchrow { display: grid; grid-template-columns: 1fr auto; gap: 10px; }
.pf-page .inv-searchrow .pf-btn-accent { white-space: nowrap; }
.pf-page .inv-results { margin-top: 10px; border: 1px solid var(--line-2); border-radius: 8px; overflow: hidden; max-height: 260px; overflow-y: auto; }
.pf-page .inv-result { display: grid; grid-template-columns: 64px 1fr auto auto; align-items: center; gap: 12px; width: 100%; padding: 11px 13px; border: 0; border-bottom: 1px solid var(--line); background: transparent; color: var(--ink-2); font-family: inherit; text-align: left; cursor: pointer; }
.pf-page .inv-result:hover { background: var(--surface-2); }
.pf-page .inv-result .sym { font-weight: 600; color: var(--da-accent); font-size: 13px; }
.pf-page .inv-result .nm { font-size: 12.5px; color: var(--ink-2); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-page .inv-result .ex { font-size: 11px; color: var(--muted-2); font-family: var(--font-mono); }
.pf-page .inv-result .ty { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--pos); background: var(--pos-fill); padding: 2px 7px; border-radius: 3px; }
.pf-page .inv-result-manual { display: block; width: 100%; padding: 11px; text-align: center; border: 0; background: transparent; }
.pf-page .inv-noresult { padding: 14px; font-size: 12.5px; color: var(--muted); text-align: center; }
.pf-page .inv-manual-link { margin-top: 10px; }
.pf-page .inv-picked { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 10px; padding: 12px 14px; border: 1px solid var(--da-accent-border); background: var(--da-accent-fill); border-radius: 8px; }
.pf-page .inv-picked .sym { font-weight: 600; color: var(--ink); margin-right: 9px; }
.pf-page .inv-picked .nm { font-size: 12.5px; color: var(--muted); }
.pf-page .inv-picked .meta { grid-column: 1; font-size: 11px; color: var(--muted-2); font-family: var(--font-mono); margin-top: 3px; }
.pf-page .inv-picked .pf-iconbtn-sm { grid-column: 2; grid-row: 1 / 3; }

/* Transaction history modal */
.pf-page .inv-txn-summary { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--line-2); border: 1px solid var(--line-2); border-radius: 6px; overflow: hidden; }
.pf-page .inv-txn-summary > div { background: var(--bg-2); padding: 11px 13px; display: flex; flex-direction: column; gap: 5px; }
.pf-page .inv-txn-summary .l { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.12em; font-weight: 600; }
.pf-page .inv-txn-summary .v { font-family: var(--font-mono); font-size: 13px; color: var(--ink); font-variant-numeric: tabular-nums; }
.pf-page .inv-txn-summary .v.pos { color: var(--pos); } .pf-page .inv-txn-summary .v.neg { color: var(--neg); }
.pf-page .inv-txn-add { border: 1px solid var(--line-2); border-radius: 8px; background: var(--bg-2); padding: 16px; display: flex; flex-direction: column; gap: 13px; }
.pf-page .inv-txn-add-head { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.13em; color: var(--muted); }
.pf-page .inv-txn-add-actions { display: flex; gap: 8px; }
.pf-page .inv-txn-list-head { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); padding: 4px 0 6px; }
.pf-page .inv-txn-list-head span { color: var(--muted-2); }
.pf-page .inv-txn-row { display: grid; grid-template-columns: 110px 96px 110px 100px 1fr auto; align-items: center; gap: 12px; padding: 11px 8px; border-top: 1px solid var(--line); border-radius: 6px; }
.pf-page .inv-txn-row:hover { background: var(--bg-2); }
.pf-page .inv-txn-row.editing { background: var(--da-accent-fill); }
.pf-page .inv-txn-row .d { font-size: 12.5px; color: var(--ink-2); }
.pf-page .inv-txn-row .badge { font-size: 9.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; padding: 3px 8px; border-radius: 3px; text-align: center; justify-self: start; }
.pf-page .inv-txn-row .badge.buy, .pf-page .inv-txn-row .badge.dividend_reinvestment, .pf-page .inv-txn-row .badge.transfer_in, .pf-page .inv-txn-row .badge.unstake { color: var(--pos); background: var(--pos-fill); }
.pf-page .inv-txn-row .badge.sell, .pf-page .inv-txn-row .badge.transfer_out, .pf-page .inv-txn-row .badge.stake { color: var(--neg); background: var(--neg-fill); }
.pf-page .inv-txn-row .badge.price_update { color: var(--da-accent); background: var(--da-accent-fill); }
.pf-page .inv-txn-row .badge.split, .pf-page .inv-txn-row .badge.staking_reward { color: var(--amber); background: rgba(255,198,109,0.12); }
.pf-page .inv-txn-row .q, .pf-page .inv-txn-row .p { font-family: var(--font-mono); font-size: 12.5px; color: var(--ink); font-variant-numeric: tabular-nums; }
.pf-page .inv-txn-row .nt { font-size: 12px; color: var(--muted); font-style: italic; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pf-page .inv-txn-row .act { display: inline-flex; gap: 5px; }
.pf-page .inv-txn-empty { font-size: 12.5px; color: var(--muted); padding: 14px 4px; }

@media (max-width: 720px) {
  .pf-page .inv-totals, .pf-page .inv-txn-summary { grid-template-columns: repeat(2, 1fr); }
  .pf-page .inv-pos { grid-template-columns: 1fr auto; grid-template-areas: "main val" "act act"; }
  .pf-page .inv-pos-main { grid-area: main; } .pf-page .inv-pos-val { grid-area: val; } .pf-page .inv-pos-act { grid-area: act; justify-content: flex-end; }
  .pf-page .inv-txn-row { grid-template-columns: 1fr auto auto; grid-template-areas: "d badge act" "q p act" "nt nt act"; row-gap: 4px; }
  .pf-page .inv-txn-row .d { grid-area: d; } .pf-page .inv-txn-row .badge { grid-area: badge; } .pf-page .inv-txn-row .q { grid-area: q; } .pf-page .inv-txn-row .p { grid-area: p; text-align: right; } .pf-page .inv-txn-row .nt { grid-area: nt; white-space: normal; } .pf-page .inv-txn-row .act { grid-area: act; }
}
