:root {
  --ink: #0F1923;
  --ink-2: #1a2534;
  --muted: #525252;
  --muted-2: #737373;
  --muted-3: #a3a3a3;
  --line: #e5e5e5;
  --line-2: #f0f0f0;
  --line-3: #f7f7f7;
  --paper: #ffffff;
  --paper-2: #fafafa;
  --paper-3: #f5f5f5;
  --accent: #B08D57;
  --accent-hover: #8F6F3E;
  --accent-soft: #F7F1E6;
  --accent-soft-2: #FBF7F0;
  --green: #2f7a4d;
  --green-soft: #f0f7f3;
  --green-on-dark: #3FA86A;
  --red: #c94a3e;
  --red-soft: #fbe9e7;
  --red-on-dark: #E27F75;
  --amber: #b87f2a;
  --amber-soft: #f7eedf;
  --amber-on-dark: #E0A458;
  --blue: #3b5ea5;
  --blue-soft: #eef2f8;
  --blue-on-dark: #5C8AD9;
  --fi: #1F3F70;
  --fi-2: #2B5499;
  --fi-soft: #E8EEF7;
  --fi-soft-2: #F3F6FB;
  --fi-on-dark: #6F9BD9;
  --ff-body: 'DM Sans', system-ui, -apple-system, Segoe UI, sans-serif;
  --ff-mono: 'DM Sans', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --max-w: 1440px;
  --inner-pad: 32px;
  --ease-smooth: cubic-bezier(0.2, 0.8, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 0.15s;
  --dur-base: 0.3s;
  --dur-slow: 0.7s;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--ff-body); color: var(--ink); background: var(--paper);
  line-height: 1.5; text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; border: 0; background: none; padding: 0; cursor: pointer; }
img, svg { display: block; max-width: 100%; }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, h5, h6 { margin: 0; line-height: 1.1; font-weight: 600; }
p { margin: 0; }
.faq-a a { color: var(--accent); border-bottom: 1px solid rgba(176,141,87,0.35); transition: border-color var(--dur-fast); }
.faq-a a:hover { border-bottom-color: var(--accent); }
.wrap { max-width: var(--max-w); margin: 0 auto; padding-left: var(--inner-pad); padding-right: var(--inner-pad); }
main > section { padding: 96px var(--inner-pad); border-bottom: 1px solid var(--line); }
main > section.section-tight { padding: 80px var(--inner-pad); }
.bg-paper-2 { background: var(--paper-2); }
.bg-ink { background: var(--ink); color: #fff; }

/* Type */
.eyebrow { font-size: 15px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); }
.lede { font-size: 18px; line-height: 1.6; color: var(--muted); }
.h-display { font-size: clamp(48px, 5.2vw, 76px); font-weight: 600; letter-spacing: -0.03em; line-height: 1.05; }
.h-section { font-size: clamp(40px, 4.2vw, 60px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.08; }
.h-section-sm { font-size: clamp(36px, 3.8vw, 52px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; }
.h-section-xs { font-size: clamp(32px, 3.4vw, 44px); font-weight: 600; letter-spacing: -0.02em; line-height: 1.12; }
.mono { font-family: var(--ff-mono); }
.num { font-variant-numeric: tabular-nums; }

/* Buttons */
.btn {
  font-family: inherit; font-size: 16px; font-weight: 500;
  padding: 13px 22px; border: 1px solid transparent; border-radius: 0;
  cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  gap: 8px; white-space: nowrap; text-decoration: none;
  transition: background var(--dur-fast) var(--ease-smooth),
              color var(--dur-fast) var(--ease-smooth),
              border-color var(--dur-fast) var(--ease-smooth),
              transform var(--dur-fast) var(--ease-smooth),
              box-shadow var(--dur-base) var(--ease-smooth);
}
.btn:hover  { transform: translateY(-1px); }
.btn:active { transform: translateY(0); transition-duration: 0s; }
.btn-accent { background: var(--accent); color: #fff; }
.btn-accent:hover { background: var(--accent-hover); box-shadow: 0 10px 28px -10px rgba(176, 141, 87, 0.55); }
.btn-ink { background: var(--ink); color: #fff; }
.btn-ink:hover { background: var(--ink-2); box-shadow: 0 10px 28px -10px rgba(15, 25, 35, 0.5); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); background: var(--paper-2); }
.btn-ghost-inv { background: transparent; color: #fff; border-color: rgba(255,255,255,0.25); }
.btn-ghost-inv:hover { border-color: rgba(255,255,255,0.6); background: rgba(255,255,255,0.04); }
.btn-lg { padding: 16px 26px; font-size: 17px; font-weight: 600; }
.link-arrow {
  font-size: 16px; font-weight: 500; color: var(--accent);
  display: inline-flex; align-items: center; gap: 6px;
  transition: gap var(--dur-fast) var(--ease-smooth);
}
.link-arrow:hover { gap: 10px; }

/* HEADER (shared with sibling pages) */
.site-header { position: sticky; top: 0; z-index: 100; background: var(--paper); border-bottom: 1px solid var(--line); }
.pulse-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: pulse 2s ease-in-out infinite; flex: none; }
.site-nav { background: var(--paper); }
.site-nav-inner { max-width: var(--max-w); margin: 0 auto; padding: 14px var(--inner-pad); display: flex; align-items: center; justify-content: space-between; }
.site-nav-left { display: flex; align-items: center; gap: 44px; }
.site-nav-right { display: flex; align-items: center; gap: 10px; }
.nav-list { display: flex; align-items: center; gap: 22px; }
.nav-link { font-size: 16.5px; font-weight: 500; color: var(--ink); padding: 8px 4px; transition: color var(--dur-fast); }
.nav-link:hover { color: var(--accent); }
.nav-link.is-current { color: var(--accent); position: relative; }
.nav-link.is-current::after { content: ""; position: absolute; left: 4px; right: 4px; bottom: 0; height: 2px; background: var(--accent); }
.nav-signin { font-size: 16px; padding: 8px 12px; color: var(--ink); }
.nav-signin:hover { color: var(--accent); }
.nav-cta { padding: 10px 18px; }
.nav-hamburger { display: none; width: 36px; height: 36px; flex-direction: column; justify-content: center; align-items: center; gap: 5px; padding: 0; background: none; border: 0; }
.nav-hamburger span { display: block; width: 20px; height: 2px; background: var(--ink); }
.edma-logo { display: inline-flex; align-items: center; gap: 8px; color: var(--ink); font-weight: 700; font-size: 22px; letter-spacing: -0.01em; }
.edma-logo .phoenix { height: 34px; width: auto; display: block; }
.edma-wordmark { font-family: var(--ff-body); }
.breadcrumb-bar { border-bottom: 1px solid var(--line); background: var(--paper); }
.breadcrumb-inner { max-width: var(--max-w); margin: 0 auto; padding: 12px var(--inner-pad); font-family: var(--ff-mono); font-size: 13px; color: var(--muted-2); letter-spacing: 0.06em; text-transform: uppercase; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.breadcrumb-inner a { color: var(--muted-2); transition: color var(--dur-fast); }
.breadcrumb-inner a:hover { color: var(--accent); }
.breadcrumb-inner .sep { color: var(--muted-3); }
.breadcrumb-inner .here { color: var(--accent); }
.breadcrumb-inner .moved-tag { color: var(--muted-2); border: 1px solid var(--line); background: var(--paper-2); padding: 1px 6px; letter-spacing: 0.08em; }
.breadcrumb-inner .moved-tag b { color: var(--accent); font-weight: 600; letter-spacing: 0.08em; }

/* ============== HERO ============== */
.s-hero { text-align: center; padding-bottom: 56px; }
.s-hero-inner { max-width: 1080px; margin: 0 auto; }
.s-hero .eyebrow { display: inline-block; margin-bottom: 28px; }
.s-hero h1 { margin-bottom: 24px; }
.s-hero .lede { max-width: 940px; margin: 0 auto 36px; }
.cta-row { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

.hero-ticker {
  display: inline-flex; align-items: center; gap: 14px;
  margin: 0 auto 40px;
  padding: 9px 16px;
  background: var(--ink); color: rgba(255,255,255,0.9);
  font-family: var(--ff-mono); font-size: 14px;
  letter-spacing: 0.02em; flex-wrap: wrap; justify-content: center;
}
.hero-ticker .ti-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 2px 8px; background: rgba(176,141,87,0.18); color: var(--accent);
  border: 1px solid rgba(176,141,87,0.4);
}
.hero-ticker .ti-sep { color: rgba(255,255,255,0.25); }
.hero-ticker .ti-dot { width: 6px; height: 6px; background: var(--green-on-dark); border-radius: 50%; }
.hero-ticker .ti-num { color: #fff; }

.hero-kpi { max-width: 1240px; margin: 64px auto 0; display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.hero-kpi-cell { padding: 22px 24px; border-right: 1px solid var(--line-2); text-align: left; }
.hero-kpi-cell:last-child { border-right: 0; }
.hero-kpi-label { font-size: 13px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted-2); }
.hero-kpi-val { margin-top: 10px; font-family: var(--ff-mono); font-size: 22px; color: var(--ink); letter-spacing: -0.01em; line-height: 1.25; }
.hero-kpi-val .unit { font-size: 15px; color: var(--muted-2); margin-left: 0; display: block; margin-top: 4px; }
.hero-kpi-val .strong-mark { color: var(--accent); }
.hero-kpi-val .pos { color: var(--green); }
.hero-kpi-val .zero { color: var(--accent); font-size: 26px; }

/* ============== CENTERPIECE — operator listings ============== */
.s-cockpit { background: var(--ink); color: #fff; padding: 88px var(--inner-pad) 96px; border-bottom: 1px solid var(--line); }
.s-cockpit-inner { max-width: 1360px; margin: 0 auto; }
.s-cockpit-head { text-align: center; max-width: 880px; margin: 0 auto 48px; }
.s-cockpit-head .eyebrow { color: var(--accent); margin-bottom: 18px; display: inline-block; }
.s-cockpit-head h2 { color: #fff; margin-bottom: 16px; }
.s-cockpit-head p.lede { color: rgba(255,255,255,0.65); max-width: 720px; margin: 0 auto; }

.portal-frame {
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.08);
}
.portal-bar {
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  padding: 14px 20px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background: rgba(0,0,0,0.25);
  flex-wrap: wrap;
}
.portal-bar-left { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.portal-bar .who {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-mono); font-size: 13px; color: rgba(255,255,255,0.85);
  letter-spacing: 0.04em;
}
.portal-bar .who .av {
  width: 24px; height: 24px;
  background: var(--accent); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600;
}
.portal-bar .scope {
  font-family: var(--ff-mono); font-size: 12.5px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.1em; text-transform: uppercase;
}
.portal-bar .tabs { display: inline-flex; gap: 4px; }
.portal-bar .tabs .tab {
  font-family: var(--ff-mono); font-size: 12.5px;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 5px 10px; color: rgba(255,255,255,0.5);
  border: 1px solid rgba(255,255,255,0.08);
}
.portal-bar .tabs .tab.is-active {
  color: #fff; background: rgba(176,141,87,0.14);
  border-color: rgba(176,141,87,0.45);
}
.portal-bar .meta {
  display: inline-flex; gap: 14px;
  font-family: var(--ff-mono); font-size: 12.5px; color: rgba(255,255,255,0.55);
  letter-spacing: 0.04em;
}
.portal-bar .meta b { color: #fff; font-weight: 500; }

/* Main cockpit layout — listings on left, analytics rail on right */
.cockpit-body {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0;
}
.listings-col {
  border-right: 1px solid rgba(255,255,255,0.08);
  display: flex; flex-direction: column;
}
.analytics-col {
  padding: 22px 22px 24px;
  background: rgba(255,255,255,0.015);
  display: flex; flex-direction: column; gap: 22px;
}

/* Listing card */
.listing {
  padding: 22px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  display: flex; flex-direction: column; gap: 16px;
}
.listing:last-child { border-bottom: 0; }
.listing.is-active {
  background: rgba(176,141,87,0.04);
  border-left: 2px solid var(--accent);
}
.listing.is-funded {
  background: rgba(63,168,106,0.025);
  border-left: 2px solid var(--green-on-dark);
}
.listing.is-live {
  background: rgba(255,255,255,0.01);
  border-left: 2px solid var(--blue-on-dark);
}
.listing-head {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 16px;
  flex-wrap: wrap;
}
.listing-id {
  display: flex; flex-direction: column; gap: 4px;
}
.listing-id .lid {
  font-family: var(--ff-mono); font-size: 12.5px; color: var(--accent);
  letter-spacing: 0.14em; font-weight: 600; text-transform: uppercase;
}
.listing-id h3 {
  font-size: 19px; font-weight: 600; color: #fff;
  letter-spacing: -0.005em; line-height: 1.3;
}
.listing-id .sub {
  font-family: var(--ff-mono); font-size: 12.5px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.04em;
  margin-top: 2px;
}
.listing-status {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-mono); font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
  padding: 5px 10px; border: 1px solid;
}
.listing-status .dot { width: 6px; height: 6px; background: currentColor; }
.listing-status.is-under-offer { color: var(--accent); border-color: rgba(176,141,87,0.45); background: rgba(176,141,87,0.12); }
.listing-status.is-funded-tag { color: var(--green-on-dark); border-color: rgba(63,168,106,0.45); background: rgba(63,168,106,0.1); }
.listing-status.is-live-tag { color: var(--blue-on-dark); border-color: rgba(92,138,217,0.4); background: rgba(92,138,217,0.1); }

/* Anonymous summary chip-line shown to financiers */
.anon-summary {
  padding: 12px 14px;
  background: rgba(0,0,0,0.3);
  border-left: 2px solid var(--accent);
  font-family: var(--ff-mono); font-size: 13px;
  color: rgba(255,255,255,0.8); line-height: 1.5;
  display: flex; flex-direction: column; gap: 6px;
}
.anon-summary .k {
  font-size: 11px; color: rgba(255,255,255,0.45);
  letter-spacing: 0.14em; text-transform: uppercase;
  display: inline-block; margin-right: 6px;
}
.anon-summary .chips {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.anon-summary .chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 8px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  font-size: 12.5px;
}
.anon-summary .chip b { color: #fff; font-weight: 500; }
.anon-summary .chip.is-pos b { color: var(--green-on-dark); }
.anon-summary .chip.is-warn b { color: var(--amber-on-dark); }

.signals-row {
  display: flex; gap: 6px; flex-wrap: wrap;
  font-family: var(--ff-mono); font-size: 12px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
}
.signal {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 7px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}
.signal b { color: var(--green-on-dark); font-weight: 500; }
.signal.is-warn b { color: var(--amber-on-dark); }

/* Offers list */
.offers-head {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--ff-mono); font-size: 12px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.offers-head .count { color: var(--accent); }
.offers-list { display: flex; flex-direction: column; gap: 1px; }
.offer {
  display: grid;
  grid-template-columns: 1.4fr 0.7fr 0.7fr 1fr 80px;
  gap: 14px; align-items: center;
  padding: 11px 14px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  font-family: var(--ff-mono); font-size: 13.5px;
  color: #fff;
}
.offer.is-best {
  border-color: rgba(63,168,106,0.45);
  background: rgba(63,168,106,0.06);
}
.offer .fi {
  display: flex; flex-direction: column; gap: 2px;
}
.offer .fi-name { color: #fff; letter-spacing: -0.005em; }
.offer .fi-meta { font-size: 11.5px; color: rgba(255,255,255,0.45); letter-spacing: 0.06em; text-transform: uppercase; }
.offer .rate { font-size: 15px; letter-spacing: -0.01em; }
.offer.is-best .rate { color: var(--green-on-dark); }
.offer .term { color: rgba(255,255,255,0.75); }
.offer .kind { font-size: 12px; color: rgba(255,255,255,0.55); letter-spacing: 0.04em; }
.offer .state {
  font-size: 11.5px; letter-spacing: 0.14em; text-transform: uppercase;
  text-align: right; color: var(--accent); font-weight: 600;
}
.offer.is-best .state { color: var(--green-on-dark); }

.offer-actions {
  display: flex; justify-content: flex-end; align-items: center; gap: 10px;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
}
.offer-cta {
  font-family: var(--ff-mono); font-size: 12.5px;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600;
  color: var(--ink); background: var(--accent);
  padding: 7px 12px;
  display: inline-flex; align-items: center; gap: 6px;
}
.offer-cta:hover { background: var(--accent-hover); color: #fff; }

/* Funded note */
.funded-note, .live-note {
  padding: 12px 14px;
  font-family: var(--ff-mono); font-size: 13px;
  color: rgba(255,255,255,0.8); line-height: 1.5;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  flex-wrap: wrap;
}
.funded-note {
  background: rgba(63,168,106,0.08);
  border: 1px solid rgba(63,168,106,0.3);
}
.live-note {
  background: rgba(92,138,217,0.08);
  border: 1px solid rgba(92,138,217,0.3);
}
.funded-note b { color: var(--green-on-dark); font-weight: 500; }
.live-note b { color: var(--blue-on-dark); font-weight: 500; }
.funded-note .k, .live-note .k { font-size: 11.5px; color: rgba(255,255,255,0.5); letter-spacing: 0.14em; text-transform: uppercase; }

/* Listing 1 — accept best offer → funded micro-interaction */
.mkt-sim { position: relative; }
.mkt-sim.is-reset * { transition: none !important; }
.mkt-result { display: flex; flex-direction: column; }

.mkt-sim .offer { transition: opacity .4s ease, background .35s ease, border-color .35s ease; }
.mkt-sim .offer .state { transition: color .3s ease; }
.offer.is-accepted { border-color: rgba(63,168,106,0.8); background: rgba(63,168,106,0.18); }
.offer.is-accepted .state { color: var(--green-on-dark); }
.offer.is-dim { opacity: 0.36; }

.mkt-collapse { display: grid; transition: grid-template-rows .55s cubic-bezier(.4,0,.2,1), opacity .4s ease; }
.mkt-collapse.is-open { grid-template-rows: 1fr; opacity: 1; }
.mkt-collapse.is-shut { grid-template-rows: 0fr; opacity: 0; }
.mkt-collapse-inner { overflow: hidden; min-height: 0; }

.mkt-cursor {
  position: absolute; top: 0; left: 0; width: 22px; height: 22px;
  pointer-events: none; z-index: 6; opacity: 0;
  transition: transform .55s cubic-bezier(.4,0,.2,1), opacity .3s ease;
  will-change: transform, opacity;
  filter: drop-shadow(0 2px 5px rgba(0,0,0,0.55));
}
.mkt-cursor svg { display: block; }
.mkt-cursor-ring {
  position: absolute; top: 50%; left: 50%;
  width: 10px; height: 10px; margin: -5px 0 0 -5px;
  border: 2px solid var(--green-on-dark); border-radius: 50%;
  transform: scale(0.3); opacity: 0;
}
.mkt-cursor.is-click .mkt-cursor-ring { animation: mktRing .5s ease-out; }
@keyframes mktRing {
  0% { transform: scale(0.3); opacity: 0.85; }
  100% { transform: scale(3.4); opacity: 0; }
}
@media (prefers-reduced-motion: reduce) {
  .mkt-cursor { display: none; }
  .mkt-collapse, .mkt-sim .offer { transition: none; }
}

/* Analytics rail */
.analytics-col h4 {
  font-family: var(--ff-mono); font-size: 12px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
  padding-bottom: 10px; border-bottom: 1px dashed rgba(255,255,255,0.12);
  margin-bottom: 4px;
}
.an-stat {
  display: flex; flex-direction: column; gap: 4px;
  padding-bottom: 14px;
  border-bottom: 1px dashed rgba(255,255,255,0.08);
}
.an-stat:last-of-type { border-bottom: 0; padding-bottom: 0; }
.an-stat .k {
  font-family: var(--ff-mono); font-size: 12px;
  color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase;
}
.an-stat .v {
  font-family: var(--ff-mono); font-size: 22px;
  color: #fff; letter-spacing: -0.01em; line-height: 1.15;
}
.an-stat .v .pos { color: var(--green-on-dark); }
.an-stat .v .acc { color: var(--accent); }
.an-stat .sub {
  font-family: var(--ff-mono); font-size: 12px;
  color: rgba(255,255,255,0.45); letter-spacing: 0.04em;
}
.spread-bar {
  display: flex; align-items: stretch; height: 18px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  margin-top: 4px;
  position: relative;
}
.spread-bar .bank { background: repeating-linear-gradient(45deg, transparent 0 4px, rgba(255,255,255,0.06) 4px 5px); flex: 1; }
.spread-bar .edma { background: var(--accent); width: 92%; position: absolute; left: 0; top: 0; bottom: 0; }
.spread-bar .delta {
  position: absolute; right: 6px; top: 50%; transform: translateY(-50%);
  font-family: var(--ff-mono); font-size: 12px; color: var(--green-on-dark);
  letter-spacing: 0.04em;
}

.cockpit-annot {
  margin-top: 28px;
  padding: 18px 22px;
  background: rgba(176,141,87,0.06);
  border: 1px solid rgba(176,141,87,0.3);
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  flex-wrap: wrap;
}
.cockpit-annot .l {
  font-size: 16px; color: rgba(255,255,255,0.85); line-height: 1.55;
}
.cockpit-annot .l b { color: var(--accent); font-weight: 600; }
.cockpit-annot .r {
  display: inline-flex; gap: 12px; align-items: center;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
  flex-wrap: wrap;
}
.cockpit-annot .r .pill {
  padding: 5px 10px;
  border: 1px solid rgba(176,141,87,0.4);
  background: rgba(176,141,87,0.12);
  color: var(--accent); letter-spacing: 0.08em; text-transform: uppercase;
}

/* ============================================================== */
/* SECTION 2.5 — INSIDE THE MARKETPLACE (Marketplace-List, Listing-Detail-Pre, Listing-Detail-Post inline mockups) */
/* ============================================================== */
.s-mkt-fi {
  padding-top: 96px;
  padding-bottom: 96px;
  background: var(--paper-2);
}
.s-mkt-fi-inner { max-width: var(--max-w); margin: 0 auto; }

.s-mkt-fi-head { max-width: 900px; margin: 0 auto 56px; text-align: center; }
.s-mkt-fi-head .eyebrow {
  color: var(--accent); font-family: var(--ff-mono); font-size: 12.5px;
  font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 16px; display: inline-block;
}
.s-mkt-fi-head h2 { margin: 0 0 18px; }
.s-mkt-fi-head .lede {
  font-size: 17px; line-height: 1.6; color: var(--muted);
  margin: 0 auto; max-width: 820px;
}
.s-mkt-fi-head .lede strong { color: var(--ink); font-weight: 500; }

.mkt-fi-surface {
  margin-bottom: 72px;
}
.mkt-fi-surface:last-of-type { margin-bottom: 0; }
.mkt-fi-surface-head {
  max-width: 820px;
  margin: 0 auto 28px;
  text-align: center;
}
.mkt-fi-surface-eb {
  font-family: var(--ff-mono);
  font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 12px;
}
.mkt-fi-surface-head h3 {
  font-size: 24px; font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.3;
  margin-bottom: 12px;
}
.mkt-fi-surface-head > p {
  font-size: 15px; line-height: 1.6; color: var(--muted);
}
.mkt-fi-surface-head p strong { color: var(--ink); font-weight: 500; }

/* Portal frame — financier-themed (cooler, navy-tinted) */
.portal-frame-fi {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 10px 36px rgba(15, 25, 35, 0.07), 0 2px 6px rgba(15, 25, 35, 0.04);
}
.portal-frame-md { max-width: 1280px; margin: 0 auto; }

/* Portal top bar */
.portal-frame-fi .portal-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 24px;
  background: var(--ink);
  color: rgba(255,255,255,0.85);
  border-bottom: 1px solid #1a2534;
}
.portal-frame-fi .portal-bar-left {
  display: flex; align-items: center; gap: 12px;
}
.portal-frame-fi .av {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--fi-2); color: #fff;
  font-family: var(--ff-mono);
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.05em;
}
.portal-frame-fi .who-block { display: flex; flex-direction: column; line-height: 1.25; }
.portal-frame-fi .who-name { font-size: 13.5px; font-weight: 600; color: #fff; }
.portal-frame-fi .who-role { font-size: 11.5px; color: rgba(255,255,255,0.55); margin-top: 2px; }
.portal-frame-fi .portal-bar-right { display: flex; gap: 0; align-items: center; }
.portal-frame-fi .ptab {
  padding: 8px 16px;
  font-size: 12.5px; font-weight: 500;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.01em;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.portal-frame-fi .ptab.is-active {
  color: #fff;
  border-bottom-color: var(--accent);
}

/* Page header inside frame */
.mkt-fi-pheader {
  display: flex; justify-content: space-between; align-items: flex-end;
  padding: 22px 28px 18px;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.mkt-fi-crumb {
  font-family: var(--ff-mono);
  font-size: 11px; letter-spacing: 0.05em;
  color: var(--muted-2); margin-bottom: 6px;
}
.mkt-fi-h {
  font-size: 22px; font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
  display: flex; align-items: baseline; gap: 12px;
}
.mkt-fi-h-count {
  font-family: var(--ff-mono);
  font-size: 12px; font-weight: 600;
  color: var(--muted);
  background: var(--paper-2);
  padding: 3px 8px;
  border: 1px solid var(--line);
}
.mkt-fi-sub {
  font-size: 12.5px; color: var(--muted-2);
  margin-top: 8px;
}
.mkt-fi-pheader-r { display: flex; gap: 10px; align-items: center; }
.mkt-fi-toggle {
  display: inline-flex;
  border: 1px solid var(--line);
  background: var(--paper-2);
  font-size: 12px; font-weight: 500;
}
.mkt-fi-toggle span {
  padding: 6px 12px;
  color: var(--muted-2);
}
.mkt-fi-toggle span.is-active {
  background: var(--ink);
  color: #fff;
}
.mkt-fi-btn {
  padding: 6px 12px;
  border: 1px solid var(--line);
  background: var(--paper);
  font-size: 12px; font-weight: 500;
  color: var(--ink);
}

/* Filter chip bar */
.mkt-fi-chips {
  display: flex; flex-wrap: wrap; gap: 0;
  padding: 12px 28px;
  background: var(--paper-2);
  border-bottom: 1px solid var(--line);
  overflow-x: auto;
}
.mfi-chip {
  padding: 6px 12px;
  background: var(--paper);
  border: 1px solid var(--line);
  font-size: 12px; font-weight: 500;
  color: var(--ink);
  margin: 2px 6px 2px 0;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 4px;
}
.mfi-chip em {
  font-style: normal;
  color: var(--muted-2);
  font-size: 11px;
  font-family: var(--ff-mono);
}
.mfi-chip.is-active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.mfi-chip.is-active em { color: rgba(255,255,255,0.6); }

/* Two-pane grid: rail + main */
.mkt-fi-grid {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 0;
}

.mkt-fi-rail {
  border-right: 1px solid var(--line);
  background: var(--paper);
  padding: 18px 18px;
}
.mfi-card {
  margin-bottom: 18px;
}
.mfi-card-h {
  font-size: 12px; font-weight: 600;
  color: var(--ink);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 10px;
  display: flex; justify-content: space-between;
}
.mfi-card-act {
  color: var(--accent);
  font-weight: 600;
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
}
.mfi-tags { display: flex; flex-wrap: wrap; gap: 4px; }
.mfi-tag {
  padding: 3px 8px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  font-size: 11px;
  color: var(--ink);
  display: inline-flex; align-items: center; gap: 4px;
}
.mfi-x { color: var(--muted-2); cursor: pointer; }

.mfi-saved {
  padding: 8px 10px;
  border-left: 2px solid transparent;
  margin-bottom: 4px;
}
.mfi-saved.is-active {
  border-left-color: var(--accent);
  background: var(--accent-soft-2);
}
.mfi-saved-n {
  font-size: 12.5px; font-weight: 600;
  color: var(--ink);
}
.mfi-saved-s {
  font-size: 11px; color: var(--muted-2);
  margin-top: 2px;
}

.mfi-fg {
  font-size: 11px; font-weight: 600;
  color: var(--muted-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-top: 14px;
  margin-bottom: 8px;
}
.mfi-fl {
  display: flex; align-items: center; gap: 8px;
  font-size: 12.5px;
  color: var(--ink);
  padding: 4px 0;
}
.mfi-cb {
  width: 12px; height: 12px;
  border: 1px solid var(--muted-3);
  background: var(--paper);
  display: inline-block;
  flex-shrink: 0;
}
.mfi-cb.is-on {
  background: var(--accent);
  border-color: var(--accent);
}
.mfi-c {
  margin-left: auto;
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--muted-2);
}
.mfi-fl-acc {
  color: var(--accent);
  font-weight: 600;
}

/* Main column - listings table */
.mkt-fi-main {
  padding: 18px 24px 24px;
  background: var(--paper);
}
.mfi-tbl-sort {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12.5px;
  color: var(--muted);
  padding: 4px 0 14px;
}
.mfi-sort-l strong { color: var(--ink); font-weight: 600; }
.mfi-sort-r {
  font-weight: 600; color: var(--ink);
  padding: 4px 10px;
  border: 1px solid var(--line);
  background: var(--paper-2);
  font-size: 12px;
}

.mfi-tbl {
  display: flex; flex-direction: column;
  border: 1px solid var(--line);
}
.mfi-tr {
  display: grid;
  grid-template-columns: 130px 1.8fr 100px 60px 130px 80px 130px;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--line);
  align-items: center;
  font-size: 12.5px;
  background: var(--paper);
}
.mfi-tr:last-child { border-bottom: 0; }
.mfi-tr-head {
  background: var(--paper-2);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted-2);
  padding: 10px 16px;
}
.mfi-id {
  font-family: var(--ff-mono);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--accent);
  display: flex; align-items: center; gap: 6px;
}
.mfi-hl-mark {
  padding: 2px 5px;
  background: var(--ink);
  color: #fff;
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 0;
}
.mfi-tr strong { font-weight: 600; color: var(--ink); font-size: 13px; }
.mfi-tr em {
  font-style: normal;
  font-size: 11.5px;
  color: var(--muted-2);
}
.mfi-num {
  font-family: var(--ff-mono);
  font-weight: 600;
  color: var(--ink);
  font-feature-settings: 'tnum';
}
.mfi-fit {
  display: flex; align-items: center; gap: 6px;
  font-weight: 600;
  color: var(--ink);
  font-family: var(--ff-mono);
  font-feature-settings: 'tnum';
}
.mfi-fit .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.mfi-fit .dot-green { background: var(--green); }
.mfi-fit .dot-amber { background: var(--amber); }
.mfi-act {
  color: var(--accent);
  font-weight: 600;
  font-size: 12px;
  white-space: nowrap;
}
.mfi-act-on {
  color: #fff;
  background: var(--accent);
  padding: 5px 10px;
}
.mfi-tr-hl {
  background: var(--accent-soft-2);
  border-left: 3px solid var(--accent);
  padding-left: 13px;
}

.mfi-pagi {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0 0;
  font-size: 12px;
  color: var(--muted-2);
}
.mfi-pagi-r {
  display: flex; gap: 4px;
}
.mfi-pagi-r span {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line);
  font-family: var(--ff-mono);
  font-weight: 600;
  color: var(--ink);
}
.mfi-pagi-r span.is-active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.mfi-pagi-r span.is-prev { color: var(--muted-3); }

/* =========== Listing Detail (Pre & Post) =========== */
.ld-pheader {
  padding: 22px 28px 20px;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.ld-crumb {
  font-family: var(--ff-mono);
  font-size: 11px; letter-spacing: 0.05em;
  color: var(--muted-2); margin-bottom: 8px;
}
.ld-pheader-row {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 24px;
}
.ld-h {
  font-size: 22px; font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.01em;
  line-height: 1.2;
  display: flex; align-items: center; gap: 12px;
}
.ld-h-pill {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: var(--paper-2);
  color: var(--muted);
  border: 1px solid var(--line);
}
.ld-h-pill-on {
  background: var(--green-soft);
  color: var(--green);
  border-color: rgba(47,122,77,0.25);
}
.ld-h-sub {
  font-size: 13px; color: var(--muted);
  margin-top: 6px;
}
.ld-act {
  display: flex; gap: 10px;
  flex-shrink: 0;
}
.ld-btn {
  padding: 8px 14px;
  border: 1px solid var(--line);
  background: var(--paper);
  font-size: 13px; font-weight: 500;
  color: var(--ink);
  white-space: nowrap;
}
.ld-btn-on {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.ld-btn-primary {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  font-weight: 600;
}

.ld-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 0;
  background: var(--paper-2);
}
.ld-main {
  padding: 22px 28px;
  background: var(--paper);
}
.ld-rail {
  padding: 22px 24px;
  border-left: 1px solid var(--line);
  background: var(--paper-2);
}

.ld-card {
  background: var(--paper-2);
  border: 1px solid var(--line);
  padding: 16px 18px;
  margin-bottom: 16px;
}
.ld-card-h {
  font-size: 12px; font-weight: 600;
  color: var(--ink);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.ld-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 7px 0;
  border-bottom: 1px solid var(--line);
  font-size: 13px;
}
.ld-row:last-child { border-bottom: 0; }
.ld-row span { color: var(--muted); }
.ld-row strong { font-weight: 600; color: var(--ink); }

.ld-sig {
  display: grid;
  grid-template-columns: 180px 1fr 80px;
  gap: 12px;
  padding: 8px 0;
  align-items: center;
  border-bottom: 1px solid var(--line);
  font-size: 12.5px;
}
.ld-sig:last-child { border-bottom: 0; }
.ld-sig-k { color: var(--muted); }
.ld-sig-bar {
  height: 6px;
  background: var(--line);
  position: relative;
  overflow: hidden;
}
.ld-sig-fill {
  display: block;
  height: 100%;
  background: var(--green);
}
.ld-sig-v {
  font-family: var(--ff-mono);
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ink);
  text-align: right;
}

/* Right rail — Fit score card */
.ld-fit-card {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 16px 18px;
  margin-bottom: 16px;
}
.ld-fit-eb {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin-bottom: 8px;
}
.ld-fit-val {
  font-family: var(--ff-mono);
  font-size: 38px; font-weight: 700;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 6px;
  font-feature-settings: 'tnum';
}
.ld-fit-val span { font-size: 22px; margin-left: 4px; }
.ld-fit-sub {
  font-size: 11.5px; color: var(--muted-2);
  line-height: 1.5;
  margin-bottom: 14px;
}
.ld-fit-rows {
  display: flex; flex-direction: column; gap: 6px;
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.ld-fr {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 12px;
}
.ld-fr span { color: var(--muted); }
.ld-fr-on { color: var(--green); font-weight: 600; }
.ld-fr-warn { color: var(--amber); font-weight: 600; }

/* Redacted card (pre-disclosure) */
.ld-redacted {
  background: var(--ink);
  color: rgba(255,255,255,0.8);
  padding: 16px 18px;
}
.ld-redacted-eb {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}
.ld-redacted-line {
  font-size: 13px;
  padding: 6px 0;
}
.ld-blur {
  background: rgba(255,255,255,0.1);
  color: transparent;
  text-shadow: 0 0 8px rgba(255,255,255,0.4);
  padding: 2px 8px;
  letter-spacing: 0.05em;
  user-select: none;
}
.ld-redacted-foot {
  font-size: 11.5px;
  color: rgba(255,255,255,0.55);
  margin-top: 14px;
  line-height: 1.55;
}

/* Post-disclosure variants */
.ld-pheader-post {
  background: var(--accent-soft-2);
}
.ld-card-parties .ld-party {
  display: grid;
  grid-template-columns: 80px 1fr;
  grid-template-rows: auto auto;
  gap: 2px 14px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.ld-card-parties .ld-party:last-child { border-bottom: 0; }
.ld-party-role {
  grid-column: 1;
  grid-row: 1 / 3;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  align-self: center;
}
.ld-party-name {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--ink);
}
.ld-party-meta {
  font-size: 11.5px;
  color: var(--muted-2);
}

.ld-hist {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--line);
  background: var(--paper);
}
.ld-hist-cell {
  padding: 14px 12px;
  border-right: 1px solid var(--line);
  text-align: center;
}
.ld-hist-cell:last-child { border-right: 0; }
.ld-hist-v {
  font-family: var(--ff-mono);
  font-size: 22px; font-weight: 700;
  color: var(--ink);
  font-feature-settings: 'tnum';
  margin-bottom: 4px;
}
.ld-hist-k {
  font-size: 10.5px;
  color: var(--muted-2);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1.4;
}

/* Offer composer rail (post-disclosure) */
.ld-offer-card {
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 18px 18px;
}
.ld-offer-eb {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 4px;
}
.ld-offer-sub {
  font-size: 11.5px;
  color: var(--muted-2);
  margin-bottom: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.ld-offer-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid var(--line);
  font-size: 12.5px;
}
.ld-of-k { color: var(--muted); }
.ld-of-v {
  font-weight: 600; color: var(--ink);
  font-family: var(--ff-mono);
}
.ld-of-input {
  background: var(--accent-soft-2);
  padding: 3px 8px;
  border: 1px solid var(--accent);
  color: var(--accent);
}
.ld-offer-econ {
  margin-top: 14px;
  padding-top: 14px;
  background: var(--paper-2);
  margin-left: -18px;
  margin-right: -18px;
  margin-bottom: -18px;
  padding: 14px 18px;
  border-top: 1px solid var(--line);
}
.ld-of-eb {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted-2);
  margin-bottom: 8px;
}
.ld-of-econ-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 0;
  font-size: 12.5px;
}
.ld-of-econ-row span { color: var(--muted); }
.ld-of-econ-row strong {
  font-weight: 600;
  color: var(--ink);
  font-family: var(--ff-mono);
  font-feature-settings: 'tnum';
}
.ld-of-econ-row strong.dim { color: var(--muted-2); font-weight: 500; }
.ld-of-econ-row strong.acc { color: var(--accent); }
.ld-of-econ-net {
  border-top: 1px solid var(--line);
  padding-top: 8px;
  margin-top: 4px;
}
.ld-of-econ-apr strong {
  font-size: 16px;
}
.ld-of-submit {
  display: block;
  text-align: center;
  background: var(--accent);
  color: #fff;
  padding: 11px 14px;
  font-size: 13px;
  font-weight: 600;
  margin-top: 16px;
}
.ld-of-foot {
  font-size: 11px;
  color: var(--muted-2);
  margin-top: 10px;
  line-height: 1.55;
}

.s-mkt-fi-foot {
  text-align: center;
  margin-top: 56px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.65;
}
.s-mkt-fi-foot strong { color: var(--ink); font-weight: 600; }
.s-mkt-fi-foot .mono {
  font-family: var(--ff-mono);
  font-size: 13px;
  background: var(--paper);
  padding: 1px 6px;
  border: 1px solid var(--line);
}

/* Responsive — TWO breakpoints */
@media (max-width: 1080px) {
  .mkt-fi-grid { grid-template-columns: 1fr; }
  .mkt-fi-rail {
    border-right: 0;
    border-bottom: 1px solid var(--line);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
  }
  .mfi-card { margin-bottom: 0; }
  .ld-grid, .ld-grid-post { grid-template-columns: 1fr; }
  .ld-rail { border-left: 0; border-top: 1px solid var(--line); }
}
@media (max-width: 880px) {
  .mfi-tr { grid-template-columns: 1fr 100px; row-gap: 6px; padding: 14px 12px; }
  .mfi-tr-head { display: none; }
  .mfi-tr > span:nth-child(1) { grid-column: 1 / 2; font-weight: 600; }
  .mfi-tr > span:nth-child(2) { grid-column: 1 / 2; grid-row: 2; }
  .mfi-tr > span:nth-child(3) { grid-column: 2 / 3; grid-row: 1; text-align: right; }
  .mfi-tr > span:nth-child(4) { grid-column: 2 / 3; grid-row: 2; text-align: right; font-size: 11px; color: var(--muted-2); }
  .mfi-tr > span:nth-child(5), .mfi-tr > span:nth-child(6) { display: none; }
  .mfi-tr > span:nth-child(7) { grid-column: 1 / 3; grid-row: 3; text-align: right; padding-top: 6px; }
  .portal-frame-fi .portal-bar-right { display: none; }
  .mkt-fi-rail { grid-template-columns: 1fr; }
  .mkt-fi-pheader { flex-direction: column; align-items: flex-start; gap: 12px; }
  .ld-pheader-row { flex-direction: column; }
  .ld-hist { grid-template-columns: repeat(2, 1fr); }
  .ld-hist-cell:nth-child(2) { border-right: 0; }
  .ld-hist-cell:nth-child(1), .ld-hist-cell:nth-child(2) { border-bottom: 1px solid var(--line); }
  .ld-sig { grid-template-columns: 1fr; gap: 4px; }
  .ld-sig-bar { width: 100%; }
  .ld-sig-v { text-align: left; }
}

/* ============== PROBLEM CARDS ============== */
.s-prob-inner { max-width: var(--max-w); margin: 0 auto; }
.s-prob-head { max-width: 920px; margin-bottom: 56px; }
.s-prob-head h2 { margin: 16px 0 18px; }
.s-prob-head .lede { max-width: 760px; }

.prob-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--line); background: var(--paper); }
.prob-card {
  padding: 32px 30px 30px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px;
  min-height: 380px;
}
.prob-card:last-child { border-right: 0; }
.prob-card .lab {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--red); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.prob-card .lab .n {
  width: 22px; height: 22px;
  background: var(--red-soft); color: var(--red);
  border: 1px solid var(--red);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 13px;
}
.prob-card h3 {
  font-size: 20px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em; line-height: 1.35;
}
.prob-card p {
  font-size: 16px; color: var(--muted); line-height: 1.65;
}
.prob-card p strong { color: var(--ink); font-weight: 500; }
.prob-card .micro {
  margin-top: auto;
  padding: 12px 14px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--ff-mono); font-size: 13px;
  color: var(--muted); line-height: 1.5;
}
.prob-card .micro .row { display: flex; justify-content: space-between; gap: 8px; }
.prob-card .micro .row .k { color: var(--muted-2); font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; }
.prob-card .micro .row .v { color: var(--ink); }
.prob-card .micro .row .v.r { color: var(--red); }
.prob-card .micro .row .v.acc { color: var(--accent); }
.prob-card .micro .row.is-foot { border-top: 1px dashed var(--line); margin-top: 2px; padding-top: 8px; }
.prob-card .micro .header {
  font-size: 11.5px; color: var(--muted-2);
  letter-spacing: 0.14em; text-transform: uppercase;
  padding-bottom: 6px; border-bottom: 1px dashed var(--line); margin-bottom: 2px;
}

/* Timeline strip — pitch timeline */
.timeline {
  margin-top: auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  font-family: var(--ff-mono); font-size: 11.5px;
  border: 1px solid var(--line);
}
.timeline .tl-cell {
  padding: 10px 10px 12px;
  border-right: 1px solid var(--line-2);
  display: flex; flex-direction: column; gap: 6px;
}
.timeline .tl-cell:last-child { border-right: 0; }
.timeline .tl-cell .wk { color: var(--muted-2); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.timeline .tl-cell .ev { color: var(--ink); font-size: 12.5px; line-height: 1.4; }
.timeline .tl-cell.is-cold .ev { color: var(--red); }
.timeline .tl-cell .bar { height: 3px; background: var(--accent); margin-top: 2px; }
.timeline .tl-cell .bar.is-fade { background: var(--line); }
.timeline .tl-cell .bar.is-r { background: var(--red); }

/* Spread sketch — bank vs market */
.spread-card {
  margin-top: auto;
  padding: 14px 14px 12px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  font-family: var(--ff-mono); font-size: 13px;
}
.spread-card .header { font-size: 11.5px; color: var(--muted-2); letter-spacing: 0.14em; text-transform: uppercase; padding-bottom: 8px; border-bottom: 1px dashed var(--line); margin-bottom: 8px; }
.spread-card .row { display: grid; grid-template-columns: 110px 1fr 56px; gap: 8px; align-items: center; padding: 4px 0; }
.spread-card .row .lbl { color: var(--muted-2); font-size: 12px; }
.spread-card .row .track { height: 7px; background: var(--paper-3); border: 1px solid var(--line-2); position: relative; }
.spread-card .row .track .fill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--red); }
.spread-card .row.is-mkt .track .fill { background: var(--accent); }
.spread-card .row .val { color: var(--ink); text-align: right; font-size: 13px; }
.spread-card .row.is-mkt .val { color: var(--accent); }

/* ============== 5-STEP FLOW ============== */
.s-flow { background: var(--paper-2); }
.s-flow-inner { max-width: var(--max-w); margin: 0 auto; }
.s-flow-head { max-width: 920px; margin: 0 auto 56px; text-align: center; }
.s-flow-head h2 { margin: 16px 0 18px; }
.s-flow-head .lede { margin: 0 auto; max-width: 760px; }

.flow-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 0;
  border: 1px solid var(--line); background: var(--paper);
}
.flow-step {
  padding: 28px 24px 26px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 12px;
  position: relative;
}
.flow-step:last-child { border-right: 0; }
.flow-step .num-row {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--accent); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.flow-step .num {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff;
  font-size: 14px; font-weight: 700;
}
.flow-step .when {
  font-family: var(--ff-mono); font-size: 11.5px;
  color: var(--muted-2); letter-spacing: 0.12em; text-transform: uppercase;
}
.flow-step h3 {
  font-size: 18px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.005em; line-height: 1.3;
}
.flow-step p {
  font-size: 15.5px; color: var(--muted); line-height: 1.6;
}
.flow-step p strong { color: var(--ink); font-weight: 500; }
.flow-step .mini {
  margin-top: auto;
  padding: 10px 12px;
  background: var(--paper-2);
  border-left: 2px solid var(--accent);
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--muted); line-height: 1.55;
}
.flow-step .mini b { color: var(--ink); font-weight: 500; }
.flow-step .mini .acc { color: var(--accent); }
.flow-step .mini .pos { color: var(--green); }

.flow-track {
  display: grid; grid-template-columns: repeat(5, 1fr);
  border: 1px solid var(--line); border-top: 0;
  background: var(--paper);
}
.flow-track .seg {
  padding: 10px 14px;
  border-right: 1px solid var(--line);
  font-family: var(--ff-mono); font-size: 12px;
  color: var(--muted-2); letter-spacing: 0.1em; text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
}
.flow-track .seg:last-child { border-right: 0; }
.flow-track .seg .bar {
  flex: 1; height: 3px; background: var(--accent);
}
.flow-track .seg .t { color: var(--ink); font-weight: 600; }

/* ============== TWO DIRECTIONS ============== */
.s-dir-inner { max-width: var(--max-w); margin: 0 auto; }
.s-dir-head { max-width: 920px; margin: 0 auto 56px; text-align: center; }
.s-dir-head h2 { margin: 16px 0 18px; }
.s-dir-head .lede { margin: 0 auto; max-width: 760px; }

.dir-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--line); }
.dir-card {
  padding: 32px 32px 28px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 18px;
  background: var(--paper);
}
.dir-card:last-child { border-right: 0; }
.dir-card.is-op { border-top: 2px solid var(--accent); margin-top: -1px; }
.dir-card.is-sup { border-top: 2px solid var(--fi-2); margin-top: -1px; }
.dir-card .lab {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-mono); font-size: 12.5px;
  letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.dir-card.is-op .lab { color: var(--accent); }
.dir-card.is-sup .lab { color: var(--fi-2); }
.dir-card .lab .badge {
  font-family: var(--ff-mono); font-size: 11.5px;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  background: var(--accent-soft-2); color: var(--accent);
  border: 1px solid rgba(176,141,87,0.3);
}
.dir-card.is-sup .lab .badge {
  background: var(--fi-soft-2); color: var(--fi-2);
  border-color: rgba(43,84,153,0.3);
}
.dir-card h3 {
  font-size: 22px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.005em; line-height: 1.3;
}
.dir-card .tag-line {
  font-family: var(--ff-mono); font-size: 13px;
  color: var(--muted-2); letter-spacing: 0.06em;
  margin-top: -8px;
}

/* Trade-flow diagram */
.trade-flow {
  padding: 18px 20px;
  background: var(--ink); color: rgba(255,255,255,0.9);
  display: flex; flex-direction: column; gap: 12px;
}
.trade-flow .h {
  font-family: var(--ff-mono); font-size: 11.5px;
  color: rgba(255,255,255,0.55); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
  padding-bottom: 8px; border-bottom: 1px dashed rgba(255,255,255,0.1);
}
.flow-row {
  display: grid;
  grid-template-columns: 130px 1fr 130px;
  gap: 10px; align-items: center;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: rgba(255,255,255,0.85);
}
.flow-row .party {
  padding: 8px 10px;
  border: 1px solid rgba(255,255,255,0.15);
  font-size: 12.5px;
  background: rgba(255,255,255,0.04);
  text-align: center;
  letter-spacing: 0.04em;
}
.flow-row .party b { display: block; color: #fff; font-weight: 500; font-size: 13px; margin-bottom: 2px; letter-spacing: -0.005em; }
.flow-row .party .role { font-size: 11px; color: rgba(255,255,255,0.5); letter-spacing: 0.1em; text-transform: uppercase; }
.flow-row .conn {
  position: relative; height: 24px;
  display: flex; align-items: center; justify-content: center;
}
.flow-row .conn .line {
  position: absolute; left: 0; right: 0; top: 50%;
  height: 1px; background: rgba(255,255,255,0.2);
}
.flow-row .conn .lbl {
  position: relative; z-index: 1;
  padding: 2px 6px;
  background: var(--ink);
  font-size: 11.5px; color: var(--accent);
  letter-spacing: 0.08em; text-transform: uppercase;
}
.dir-card.is-sup .flow-row .conn .lbl { color: var(--fi-on-dark); }
.flow-row .conn .arr {
  position: absolute; right: 0; top: 50%; transform: translateY(-50%);
  font-size: 14px; color: var(--accent);
}
.dir-card.is-sup .flow-row .conn .arr { color: var(--fi-on-dark); }

.dir-bullets { display: flex; flex-direction: column; gap: 10px; }
.dir-bullets li {
  display: grid; grid-template-columns: 22px 1fr;
  gap: 10px; align-items: start;
  font-size: 16px; color: var(--muted); line-height: 1.55;
}
.dir-bullets li .c {
  font-family: var(--ff-mono); font-size: 13px; font-weight: 600;
  width: 20px; height: 20px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-top: 1px;
  background: var(--accent-soft-2); color: var(--accent);
  border: 1px solid rgba(176,141,87,0.3);
}
.dir-card.is-sup .dir-bullets li .c {
  background: var(--fi-soft-2); color: var(--fi-2);
  border-color: rgba(43,84,153,0.3);
}
.dir-bullets li strong { color: var(--ink); font-weight: 500; }

.dir-note {
  margin-top: auto;
  padding: 14px 16px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  font-family: var(--ff-mono); font-size: 13px;
  color: var(--muted); line-height: 1.6;
}
.dir-card.is-sup .dir-note { border-left-color: var(--fi-2); }
.dir-note b { color: var(--ink); font-weight: 500; }

/* Spans across both directions */
.dir-foot {
  grid-column: 1 / -1;
  padding: 18px 24px;
  background: var(--paper-2);
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center; gap: 18px;
  flex-wrap: wrap;
  font-family: var(--ff-mono); font-size: 13.5px;
  color: var(--muted); letter-spacing: 0.02em;
}
.dir-foot b { color: var(--ink); font-weight: 500; }
.dir-foot .acc { color: var(--accent); }
.dir-foot .pill {
  padding: 4px 10px;
  background: var(--paper); border: 1px solid var(--line);
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
  color: var(--muted-2);
}

/* ============== FINANCIER-SIDE 3 CARDS ============== */
.s-fi { background: var(--paper-2); }
.s-fi-inner { max-width: var(--max-w); margin: 0 auto; }
.s-fi-head { max-width: 920px; margin-bottom: 48px; }
.s-fi-head h2 { margin: 16px 0 18px; }
.s-fi-head .lede { max-width: 720px; }
.fi-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--line); background: var(--paper);
}
.fi-card {
  padding: 30px 28px;
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px;
}
.fi-card:last-child { border-right: 0; }
.fi-card .num {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--ff-mono); font-size: 12.5px; font-weight: 600;
  color: var(--accent); letter-spacing: 0.14em;
}
.fi-card .num .sq { width: 8px; height: 8px; background: var(--accent); }
.fi-card h3 {
  font-size: 20px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em; line-height: 1.3;
}
.fi-card p { font-size: 16px; color: var(--muted); line-height: 1.65; }
.fi-card p strong { color: var(--ink); font-weight: 500; }

/* Signals card visual */
.signals-card {
  margin-top: auto;
  padding: 14px 16px;
  background: var(--ink); color: rgba(255,255,255,0.85);
  font-family: var(--ff-mono); font-size: 13px;
  display: flex; flex-direction: column; gap: 8px;
}
.signals-card .h {
  font-size: 11.5px; color: rgba(255,255,255,0.5);
  letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
  padding-bottom: 6px; border-bottom: 1px dashed rgba(255,255,255,0.12);
}
.signals-card .row {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 3px 0;
}
.signals-card .row .k { color: rgba(255,255,255,0.55); font-size: 12px; }
.signals-card .row .v { color: #fff; }
.signals-card .row .v.pos { color: var(--green-on-dark); }
.signals-card .row .v.warn { color: var(--amber-on-dark); }
.signals-card .row .v.acc { color: var(--accent); }
.signals-card .meter {
  height: 4px; background: rgba(255,255,255,0.08); position: relative;
  margin-top: 4px;
}
.signals-card .meter .fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--green-on-dark);
}

/* Disclosure ladder */
.discl {
  margin-top: auto;
  padding: 14px 16px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  font-family: var(--ff-mono); font-size: 13px;
  color: var(--muted); line-height: 1.55;
  display: flex; flex-direction: column; gap: 8px;
}
.discl .h { font-size: 11.5px; color: var(--muted-2); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; padding-bottom: 6px; border-bottom: 1px dashed var(--line); }
.discl-step {
  display: grid;
  grid-template-columns: 22px 1fr 80px;
  gap: 8px; align-items: center;
}
.discl-step .n {
  width: 20px; height: 20px;
  background: var(--accent-soft-2); color: var(--accent);
  border: 1px solid rgba(176,141,87,0.3);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
}
.discl-step .lbl { color: var(--ink); font-size: 13px; }
.discl-step .lbl b { font-weight: 500; }
.discl-step .lbl .sub { display: block; color: var(--muted-2); font-size: 11.5px; letter-spacing: 0.04em; }
.discl-step .reveal {
  text-align: right; font-size: 11.5px; color: var(--muted-2);
  letter-spacing: 0.1em; text-transform: uppercase;
}
.discl-step .reveal.is-on { color: var(--accent); font-weight: 600; }

/* Portfolio shelf */
.portf {
  margin-top: auto;
  padding: 14px 16px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 8px;
  font-family: var(--ff-mono); font-size: 13px;
}
.portf .h { font-size: 11.5px; color: var(--muted-2); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; padding-bottom: 6px; border-bottom: 1px dashed var(--line); }
.portf-row {
  display: grid;
  grid-template-columns: 1fr 70px 60px;
  gap: 8px; align-items: center;
  padding: 3px 0;
}
.portf-row .nm { color: var(--ink); font-size: 13px; }
.portf-row .src { font-size: 11.5px; color: var(--muted-2); letter-spacing: 0.08em; text-transform: uppercase; }
.portf-row .src.is-mkt { color: var(--accent); }
.portf-row .src.is-ext { color: var(--green); }
.portf-row .amt { text-align: right; color: var(--ink); font-size: 12.5px; }

/* ============== FEES ============== */
.s-fee-inner { max-width: var(--max-w); margin: 0 auto; }
.s-fee-head { max-width: 920px; margin: 0 auto 48px; text-align: center; }
.s-fee-head h2 { margin: 16px 0 18px; }
.s-fee-head .lede { margin: 0 auto; max-width: 720px; }

.fee-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.fee-card {
  background: var(--paper); border: 1px solid var(--line);
  padding: 36px 36px 32px;
  display: flex; flex-direction: column; gap: 16px;
}
.fee-card.is-op { border-top: 2px solid var(--accent); }
.fee-card.is-fi { border-top: 2px solid var(--fi-2); }
.fee-card .who-lab {
  font-family: var(--ff-mono); font-size: 12.5px;
  letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.fee-card.is-op .who-lab { color: var(--accent); }
.fee-card.is-fi .who-lab { color: var(--fi-2); }
.fee-card .big-num {
  font-size: clamp(56px, 5.5vw, 84px); font-weight: 600;
  letter-spacing: -0.04em; line-height: 1;
  font-family: var(--ff-body);
}
.fee-card.is-op .big-num { color: var(--accent); }
.fee-card.is-fi .big-num { color: var(--fi-2); }
.fee-card .big-num .sub { font-size: 19px; color: var(--muted-2); letter-spacing: 0; font-weight: 400; margin-left: 12px; }
.fee-card h3 {
  font-size: 22px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em; line-height: 1.3;
}
.fee-card .desc {
  font-size: 16.5px; color: var(--muted); line-height: 1.65;
}
.fee-card .desc strong { color: var(--ink); font-weight: 500; }
.fee-rows {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 8px;
  font-family: var(--ff-mono); font-size: 13.5px;
}
.fee-rows .row {
  display: flex; justify-content: space-between; gap: 10px;
}
.fee-rows .row .k { color: var(--muted-2); font-size: 12.5px; letter-spacing: 0.06em; text-transform: uppercase; }
.fee-rows .row .v { color: var(--ink); }
.fee-rows .row .v.acc { color: var(--accent); }
.fee-rows .row .v.fi { color: var(--fi-2); }
.fee-rows .row .v.pos { color: var(--green); }

/* ============== SETTLEMENT WATERFALL · OPERATOR VIEW (7.5) ============== */
.s-settle { background: var(--paper); }
.s-settle-inner { max-width: var(--max-w); margin: 0 auto; }
.s-settle-head { max-width: 900px; margin: 0 auto 56px; text-align: center; }
.s-settle-head .eyebrow {
  color: var(--accent); font-family: var(--ff-mono); font-size: 12.5px;
  font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  margin-bottom: 16px; display: inline-block;
}
.s-settle-head h2 { margin: 0 0 18px; }
.s-settle-head .lede { font-size: 17px; line-height: 1.6; color: var(--muted); margin: 0 auto; max-width: 820px; }
.s-settle-head .lede strong { color: var(--ink); font-weight: 500; }

.settle-wf {
  border: 1px solid var(--line);
  background: var(--paper-2);
}
.settle-wf-head {
  padding: 28px 32px;
  background: var(--paper);
  border-bottom: 1px solid var(--line);
}
.settle-wf-head .eb {
  font-family: var(--ff-mono); font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 10px;
}
.settle-wf-head h3 {
  font-size: 20px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em; line-height: 1.3;
}

.settle-rows { display: flex; flex-direction: column; padding: 0; }
.srow {
  display: grid;
  grid-template-columns: 36px 1fr 180px;
  gap: 18px;
  padding: 18px 32px;
  border-bottom: 1px solid var(--line);
  align-items: center;
  background: var(--paper);
}
.srow:last-of-type { border-bottom: 0; }
.srow-num {
  width: 28px; height: 28px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--paper-2); border: 1px solid var(--line);
  font-family: var(--ff-mono); font-size: 13px; font-weight: 600;
  color: var(--muted-2);
  flex-shrink: 0;
}
.srow-body { min-width: 0; }
.srow-step { font-size: 15px; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.srow-sub { font-size: 12.5px; color: var(--muted-2); line-height: 1.55; }
.srow-amt {
  font-family: var(--ff-mono); font-size: 18px; font-weight: 600;
  text-align: right; color: var(--ink);
  font-feature-settings: 'tnum';
}
.srow-amt-in { color: var(--green); font-size: 20px; }
.srow-amt-neutral { color: var(--muted-2); font-size: 16px; }
.srow-amt-fee { color: var(--accent); }

.srow-in { background: var(--green-soft); }
.srow-in .srow-num { background: var(--green); color: #fff; border-color: var(--green); }
.srow-fee { background: var(--accent-soft); }
.srow-fee .srow-num { background: var(--accent); color: #fff; border-color: var(--accent); }
.srow-final {
  background: var(--accent-soft-2);
  border-top: 2px solid var(--accent);
  padding: 22px 32px;
}
.srow-final .srow-step { font-size: 16px; font-weight: 700; }
.srow-num-final { background: var(--accent); color: #fff; border-color: var(--accent); width: 32px; height: 32px; font-size: 15px; }
.srow-amt-final {
  font-size: 26px; font-weight: 700; color: var(--accent);
}

.settle-wf-foot {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--paper);
  border-top: 1px solid var(--line);
}
.sfoot-cell {
  padding: 22px 24px;
  border-right: 1px solid var(--line);
}
.sfoot-cell:last-child { border-right: 0; }
.sfoot-cell-accent { background: var(--accent-soft-2); }
.sfoot-k {
  font-family: var(--ff-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--muted-2); margin-bottom: 6px;
}
.sfoot-v {
  font-family: var(--ff-mono); font-size: 22px; font-weight: 700;
  color: var(--ink); letter-spacing: -0.01em;
  font-feature-settings: 'tnum';
  margin-bottom: 4px;
}
.sfoot-cell-accent .sfoot-v { color: var(--accent); }
.sfoot-sub { font-size: 12px; color: var(--muted); line-height: 1.5; }

.s-settle-foot {
  margin-top: 32px;
  text-align: center;
  font-size: 14px;
  color: var(--muted);
  line-height: 1.65;
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}
.s-settle-foot a { color: var(--accent); border-bottom: 1px solid rgba(176,141,87,0.4); }

@media (max-width: 960px) {
  .settle-wf-foot { grid-template-columns: repeat(2, 1fr); }
  .sfoot-cell { border-right: 0; border-bottom: 1px solid var(--line); }
  .sfoot-cell:nth-child(2) { border-right: 0; }
  .sfoot-cell:nth-child(odd) { border-right: 1px solid var(--line); }
  .sfoot-cell:nth-child(3), .sfoot-cell:nth-child(4) { border-bottom: 0; }
}
@media (max-width: 640px) {
  .srow { grid-template-columns: 28px 1fr; padding: 14px 18px; gap: 10px; }
  .srow-amt { grid-column: 1 / -1; text-align: left; padding-left: 38px; }
  .settle-wf-head { padding: 22px 18px; }
  .srow-final { padding: 18px 18px; }
  .settle-wf-foot { grid-template-columns: 1fr; }
  .sfoot-cell { border-right: 0 !important; border-bottom: 1px solid var(--line); }
  .sfoot-cell:last-child { border-bottom: 0; }
}

/* ============== VETTING ============== */
.s-vet { background: var(--paper-2); }
.s-vet-inner { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 64px; align-items: start; }
.s-vet h2 { margin: 16px 0 18px; }
.s-vet .lede { max-width: 500px; }
.s-vet .body-p {
  margin-top: 18px; font-size: 16.5px; color: var(--muted); line-height: 1.7;
}
.s-vet .body-p strong { color: var(--ink); font-weight: 500; }

.vet-checklist {
  background: var(--paper); border: 1px solid var(--line);
}
.vet-checklist .h-row {
  padding: 16px 22px;
  background: var(--paper-2);
  border-bottom: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--muted-2); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600;
}
.vet-checklist .h-row .right { color: var(--accent); }
.vet-row {
  padding: 16px 22px;
  border-bottom: 1px solid var(--line-2);
  display: grid;
  grid-template-columns: 32px 1fr 110px;
  gap: 16px; align-items: center;
}
.vet-row:last-child { border-bottom: 0; }
.vet-row .check {
  width: 28px; height: 28px;
  background: var(--green-soft); color: var(--green);
  border: 1px solid var(--green);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700;
}
.vet-row .desc h4 {
  font-size: 17px; color: var(--ink); font-weight: 600;
  margin-bottom: 4px; letter-spacing: -0.005em;
}
.vet-row .desc p {
  font-size: 15px; color: var(--muted); line-height: 1.55;
}
.vet-row .when {
  text-align: right;
  font-family: var(--ff-mono); font-size: 12px;
  color: var(--muted-2); letter-spacing: 0.1em; text-transform: uppercase;
}
.vet-row .when b { display: block; color: var(--accent); font-weight: 600; font-size: 13px; margin-bottom: 2px; }
.vet-foot {
  padding: 14px 22px;
  background: var(--ink); color: rgba(255,255,255,0.9);
  font-family: var(--ff-mono); font-size: 13.5px;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px;
}
.vet-foot .l { display: inline-flex; align-items: center; gap: 8px; }
.vet-foot .l .ic { color: var(--accent); font-size: 16px; font-weight: 700; }
.vet-foot .l b { color: #fff; font-weight: 500; }
.vet-foot .r { color: rgba(255,255,255,0.55); font-size: 12.5px; letter-spacing: 0.08em; text-transform: uppercase; }

/* ============== AI STACK ============== */
.s-ai-inner { max-width: var(--max-w); margin: 0 auto; }
.s-ai-head { max-width: 920px; margin-bottom: 48px; }
.s-ai-head h2 { margin: 16px 0 18px; }
.ai-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border: 1px solid var(--line); background: var(--paper); }
.ai-card { padding: 30px 28px; border-right: 1px solid var(--line); display: flex; flex-direction: column; gap: 14px; }
.ai-card:last-child { border-right: 0; }
.ai-card .eb {
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--accent); letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.ai-card h3 { font-size: 19px; font-weight: 600; color: var(--ink); letter-spacing: -0.005em; line-height: 1.3; }
.ai-card p { font-size: 16px; color: var(--muted); line-height: 1.65; }
.ai-card p strong { color: var(--ink); font-weight: 500; }
.ai-card .ai-mock {
  padding: 12px 14px;
  background: var(--paper-2);
  border-left: 2px solid var(--accent);
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--muted); line-height: 1.6;
  margin-top: auto;
  display: flex; flex-direction: column; gap: 4px;
}
.ai-card .ai-mock .row { display: flex; justify-content: space-between; gap: 8px; }
.ai-card .ai-mock .row .k { color: var(--muted-2); font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; }
.ai-card .ai-mock .row .v { color: var(--ink); }
.ai-card .ai-mock .row .v.pos { color: var(--green); }
.ai-card .ai-mock .row .v.acc { color: var(--accent); }
.ai-card .ai-mock .row .v.warn { color: var(--amber); }
.ai-card .ai-mock .header { font-size: 11.5px; color: var(--muted-2); letter-spacing: 0.14em; text-transform: uppercase; padding-bottom: 5px; border-bottom: 1px dashed var(--line); margin-bottom: 2px; }

/* ============== COMPARE TABLE ============== */
.s-cmp { background: var(--paper-2); }
.s-cmp-inner { max-width: var(--max-w); margin: 0 auto; }
.s-cmp-head { max-width: 920px; margin: 0 auto 56px; text-align: center; }
.s-cmp-head h2 { margin: 16px 0 18px; }
.s-cmp-head .lede { margin: 0 auto; max-width: 760px; }

.cmp-table {
  background: var(--paper); border: 1px solid var(--line);
  overflow-x: auto;
}
.cmp-table table {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
  min-width: 1000px;
}
.cmp-table thead th {
  text-align: left;
  padding: 18px 14px;
  border-bottom: 1px solid var(--line);
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--muted-2); letter-spacing: 0.12em; text-transform: uppercase; font-weight: 600;
  vertical-align: bottom;
  background: var(--paper-2);
}
.cmp-table thead th.is-edma {
  background: var(--accent); color: #fff;
  border-bottom-color: var(--accent);
}
.cmp-table thead th.is-edma .ed-sub {
  display: block; font-size: 11.5px; color: rgba(255,255,255,0.7); margin-top: 4px; letter-spacing: 0.1em;
}
.cmp-table thead th.is-col .col-sub {
  display: block; font-size: 11.5px; color: var(--muted-3); margin-top: 4px; letter-spacing: 0.04em; text-transform: none; font-family: var(--ff-mono);
}
.cmp-table tbody td {
  padding: 14px;
  border-bottom: 1px solid var(--line-2);
  font-size: 15px;
  color: var(--muted);
  vertical-align: middle;
}
.cmp-table tbody tr:last-child td { border-bottom: 0; }
.cmp-table tbody td.cap {
  color: var(--ink); font-weight: 500; font-size: 15.5px; letter-spacing: -0.005em;
  width: 28%;
}
.cmp-table tbody td.cap .sub {
  display: block; color: var(--muted-2); font-weight: 400; font-size: 13.5px; margin-top: 3px; letter-spacing: 0;
}
.cmp-table tbody td.cell {
  text-align: center;
  font-family: var(--ff-mono); font-size: 13.5px;
}
.cmp-table tbody td.cell.is-yes { color: var(--green); }
.cmp-table tbody td.cell.is-no { color: var(--muted-3); }
.cmp-table tbody td.cell.is-partial { color: var(--amber); }
.cmp-table tbody td.cell.is-edma {
  background: rgba(176,141,87,0.06);
  color: var(--accent);
  font-weight: 600;
  border-left: 1px solid rgba(176,141,87,0.25);
  border-right: 1px solid rgba(176,141,87,0.25);
}
.cmp-table tbody tr:hover td:not(.is-edma) { background: var(--paper-2); }
.cmp-table tbody td.cell .mark { font-size: 16px; font-weight: 600; }
.cmp-foot {
  margin-top: 22px;
  font-family: var(--ff-mono); font-size: 12.5px;
  color: var(--muted-2); letter-spacing: 0.04em; line-height: 1.7;
  display: flex; gap: 18px; flex-wrap: wrap;
}
.cmp-foot .leg { display: inline-flex; align-items: center; gap: 6px; }
.cmp-foot .leg .ic { width: 14px; height: 14px; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 700; border: 1px solid; }
.cmp-foot .leg.is-yes .ic { color: var(--green); border-color: var(--green); background: var(--green-soft); }
.cmp-foot .leg.is-no .ic { color: var(--muted-3); border-color: var(--muted-3); background: var(--paper); }
.cmp-foot .leg.is-part .ic { color: var(--amber); border-color: var(--amber); background: var(--amber-soft); }

/* ============== FAQ ============== */
.s-faq-inner { max-width: var(--max-w); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.6fr; gap: 80px; align-items: start; }
.s-faq h2 { margin-bottom: 16px; }
.faq-item { padding: 24px 0; border-bottom: 1px solid var(--line-2); }
.faq-item:first-child { padding-top: 0; }
.faq-item:last-child { border-bottom: 0; }
.faq-q { font-size: 20px; font-weight: 600; color: var(--ink); margin-bottom: 12px; letter-spacing: -0.01em; }
.faq-a { font-size: 17.5px; line-height: 1.7; color: var(--muted); }

/* ============== CTA ============== */
.s-cta { background: var(--ink); color: #fff; border-bottom: 0; }
.s-cta-inner { max-width: 940px; margin: 0 auto; text-align: center; }
.s-cta h2 { color: #fff; margin-bottom: 18px; }
.s-cta p { color: rgba(255,255,255,0.7); font-size: 18px; line-height: 1.6; margin-bottom: 32px; }
.s-cta .cta-row { justify-content: center; }
.s-cta .link-arrow { color: var(--accent); margin-top: 22px; display: inline-flex; }

/* ============== RELATED ============== */
.s-related-inner { max-width: var(--max-w); margin: 0 auto; }
.s-related h3 { margin-bottom: 32px; font-size: 15px; font-weight: 500; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted-2); }
.related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.related-card {
  background: var(--paper); border: 1px solid var(--line); padding: 26px;
  transition: border-color var(--dur-base) var(--ease-smooth), transform var(--dur-base) var(--ease-smooth);
  display: flex; flex-direction: column; gap: 10px;
}
.related-card:hover { border-color: var(--ink); transform: translateY(-2px); }
.related-card-eyebrow { font-size: 12.5px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.related-card-title { font-size: 18px; font-weight: 600; letter-spacing: -0.01em; color: var(--ink); line-height: 1.25; }
.related-card-desc { font-size: 15px; color: var(--muted); line-height: 1.55; }
.related-card-link { color: var(--accent); font-size: 14.5px; font-weight: 500; margin-top: auto; padding-top: 8px; }

/* ============== FOOTER (shared) ============== */
.site-footer { background: var(--ink); color: #fff; }
.footer-top { border-bottom: 1px solid rgba(255,255,255,0.08); }
.footer-top-inner { max-width: var(--max-w); margin: 0 auto; padding: 48px var(--inner-pad); display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: start; }
.edma-logo--footer .phoenix { height: 40px; }
.edma-logo--footer .edma-wordmark { font-size: 26px; color: #fff; }
.edma-logo--footer { color: #fff; }
.footer-brand-tag { color: rgba(255,255,255,0.55); font-size: 16px; line-height: 1.55; margin-top: 14px; max-width: 480px; }
.footer-newsletter-title { color: #fff; font-size: 15px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
.footer-newsletter-sub { color: rgba(255,255,255,0.55); font-size: 15px; margin-bottom: 14px; }
.footer-newsletter { display: flex; gap: 8px; }
.footer-newsletter input { flex: 1; padding: 12px 14px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.12); color: #fff; font-family: inherit; font-size: 15px; outline: none; }
.footer-newsletter input::placeholder { color: rgba(255,255,255,0.35); }
.footer-newsletter input:focus { border-color: var(--accent); }
.footer-newsletter button { padding: 12px 18px; background: var(--accent); color: #fff; font-family: inherit; font-size: 15px; font-weight: 500; border: 0; cursor: pointer; }
.footer-newsletter button:hover { background: var(--accent-hover); }
.footer-links { max-width: var(--max-w); margin: 0 auto; padding: 56px var(--inner-pad); display: grid; grid-template-columns: repeat(6, 1fr); gap: 32px; border-bottom: 1px solid rgba(255,255,255,0.08); }
.footer-col-title { font-size: 14px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 16px; }
.footer-link-list li { padding: 4px 0; }
.footer-link-list a { font-size: 15px; color: rgba(255,255,255,0.65); transition: color var(--dur-fast); }
.footer-link-list a:hover { color: #fff; }
.footer-logos { border-bottom: 1px solid rgba(255,255,255,0.08); }
.footer-logos-inner { max-width: var(--max-w); margin: 0 auto; padding: 32px var(--inner-pad); display: flex; align-items: center; gap: 32px; flex-wrap: wrap; }
.footer-logos-label { font-size: 13px; font-weight: 600; letter-spacing: 0.12em; color: rgba(255,255,255,0.5); text-transform: uppercase; }
.footer-logos-row { display: flex; gap: 36px; flex-wrap: wrap; flex: 1; }
.footer-logos-row li { font-size: 14px; font-weight: 600; letter-spacing: 0.06em; color: rgba(255,255,255,0.4); }
.footer-region { border-bottom: 1px solid rgba(255,255,255,0.08); }
.footer-region-inner { max-width: var(--max-w); margin: 0 auto; padding: 22px var(--inner-pad); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-region-left, .footer-social { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; font-size: 14.5px; color: rgba(255,255,255,0.7); }
.footer-region-left .label, .footer-social .label { font-size: 13px; font-weight: 600; letter-spacing: 0.1em; color: rgba(255,255,255,0.4); text-transform: uppercase; }
.footer-region-left a:hover { color: #fff; }
.footer-region-divider { color: rgba(255,255,255,0.2); }
.footer-region-left a.is-muted { color: rgba(255,255,255,0.4); }
.footer-social-icon { width: 30px; height: 30px; border: 1px solid rgba(255,255,255,0.15); display: inline-flex; align-items: center; justify-content: center; font-size: 14px; font-weight: 600; }
.footer-social-icon:hover { border-color: var(--accent); color: var(--accent); }
.footer-legal-inner { max-width: var(--max-w); margin: 0 auto; padding: 18px var(--inner-pad); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-size: 14px; color: rgba(255,255,255,0.45); }
.footer-legal-inner .links { display: flex; gap: 18px; flex-wrap: wrap; }
.footer-legal-inner .status-ok { color: var(--green-on-dark); }

/* ============== RESPONSIVE ============== */
@media (max-width: 1200px) {
  .hero-kpi { grid-template-columns: repeat(2, 1fr); }
  .hero-kpi-cell:nth-child(2) { border-right: 0; }
  .hero-kpi-cell:nth-child(1), .hero-kpi-cell:nth-child(2) { border-bottom: 1px solid var(--line-2); }
  .cockpit-body { grid-template-columns: 1fr; }
  .listings-col { border-right: 0; border-bottom: 1px solid rgba(255,255,255,0.08); }
  .analytics-col { flex-direction: row; flex-wrap: wrap; gap: 18px; }
  .analytics-col > * { flex: 1 1 220px; }
  .prob-grid { grid-template-columns: 1fr; }
  .prob-card { border-right: 0; border-bottom: 1px solid var(--line); }
  .prob-card:last-child { border-bottom: 0; }
  .flow-grid, .flow-track { grid-template-columns: repeat(5, 1fr); }
  .dir-grid { grid-template-columns: 1fr; }
  .dir-card { border-right: 0; border-bottom: 1px solid var(--line); }
  .fi-grid { grid-template-columns: 1fr; }
  .fi-card { border-right: 0; border-bottom: 1px solid var(--line); }
  .fi-card:last-child { border-bottom: 0; }
  .fee-grid { grid-template-columns: 1fr; }
  .s-vet-inner { grid-template-columns: 1fr; gap: 40px; }
  .ai-grid { grid-template-columns: 1fr; }
  .ai-card { border-right: 0; border-bottom: 1px solid var(--line); }
  .ai-card:last-child { border-bottom: 0; }
  .s-faq-inner { grid-template-columns: 1fr; gap: 40px; }
  .related-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-links { grid-template-columns: repeat(3, 1fr); }
  .footer-top-inner { grid-template-columns: 1fr; gap: 32px; }
  .offer { grid-template-columns: 1.2fr 0.6fr 0.6fr 0.9fr 70px; gap: 10px; }
}
@media (max-width: 900px) {
  .flow-grid, .flow-track { grid-template-columns: 1fr; }
  .flow-step { border-right: 0; border-bottom: 1px solid var(--line); }
  .flow-track .seg { border-right: 0; border-bottom: 1px solid var(--line); }
}
@media (max-width: 768px) {
  :root { --inner-pad: 20px; }
  main > section { padding: 56px 20px; }
  .s-cockpit { padding: 56px 20px; }
  .nav-list, .nav-signin, .nav-link-pricing { display: none; }
  .nav-cta { display: inline-flex; font-size: 14px; padding: 8px 14px; }
  .nav-hamburger { display: flex; }
  .hero-kpi { grid-template-columns: 1fr; }
  .hero-kpi-cell { border-right: 0; border-bottom: 1px solid var(--line-2); }
  .hero-kpi-cell:last-child { border-bottom: 0; }
  .related-grid { grid-template-columns: 1fr; }
  .footer-links { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .h-display { font-size: 40px; }
  .h-section { font-size: 32px; }
  .h-section-sm { font-size: 28px; }
  .h-section-xs { font-size: 26px; }
  .offer {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .offer .state { text-align: left; }
  .flow-row { grid-template-columns: 1fr; gap: 6px; }
  .flow-row .conn { display: none; }
  .vet-row { grid-template-columns: 1fr; gap: 8px; }
  .vet-row .when { text-align: left; }
}
@media (max-width: 480px) {
  .footer-links { grid-template-columns: 1fr; }
  .hero-kpi-val { font-size: 19px; }
}

/* ============== MOBILE COMPRESSION — hide heavy mocks <768px ============== */
@media (max-width: 768px) {
  /* Cockpit centerpiece — 3 listings dashboard mock + annotations */
  .s-cockpit .cockpit-body { display: none !important; }
  .s-cockpit .cockpit-annot { display: none !important; }
  /* Inside the marketplace — 3 financier-side surfaces (very heavy) */
  .s-mkt-fi .mkt-fi-surface { display: none !important; }
  /* AI stack 3-card mock pre blocks */
  .s-ai .ai-mock { display: none !important; }
  /* Compare table — allow horizontal scroll on overflow */
  .s-cmp .cmp-table-wrap { overflow-x: auto; }
}
