:root {
  color-scheme: light;
  /* IWHF Design Guide v2.0 is the source of truth for these tokens. */
  --forest: #0f3d34;
  --forest-deep: #092a24;
  --forest-glow: #1a5c4f;
  --forest-mist: #e3ece9;
  --champagne: #c8a55e;
  --champagne-deep: #9a7b3c;
  --champagne-soft: #efe6d2;
  --champagne-mist: #f7f1e1;
  --mark-black: #050505;
  --ink: #0b0b0c;
  --ink-soft: #1a1a1f;
  --bone: #faf8f3;
  --aubergine: #2b1b2e;
  --plum: #3b2a42;
  --mauve: #8b8191;
  --clay: #b99667;
  --sage: #6b8073;
  --stone: #d4cfc4;
  --paper: #f2ede5;
  --paper-warm: #f6f0e3;
  --charcoal: #1a1a1f;
  --slate: #4a4a52;
  --slate-soft: #6b6b75;
  --surface: #ffffff;
  --signal-up: #1f8a5b;
  --signal-up-soft: rgba(31, 138, 91, 0.08);
  --signal-down: #b3473a;
  --signal-down-soft: rgba(179, 71, 58, 0.08);
  --signal-watch: #c69a3e;
  --signal-watch-soft: rgba(198, 154, 62, 0.10);
  --signal-info: #2c5e9c;
  --signal-info-soft: rgba(44, 94, 156, 0.08);
  --hairline: rgba(11, 11, 12, 0.08);
  --hairline-strong: rgba(11, 11, 12, 0.18);
  --hairline-soft: rgba(11, 11, 12, 0.04);
  --hairline-gold: rgba(200, 165, 94, 0.35);
  --elev-0: none;
  --elev-1: 0 1px 2px rgba(11, 11, 12, 0.04);
  --elev-2: 0 4px 12px rgba(11, 11, 12, 0.06);
  --elev-3: 0 12px 32px rgba(11, 11, 12, 0.08), 0 2px 6px rgba(11, 11, 12, 0.04);
  --elev-4: 0 22px 56px rgba(11, 11, 12, 0.10), 0 2px 6px rgba(11, 11, 12, 0.04);
  --elev-5: 0 36px 90px rgba(11, 11, 12, 0.14);
  --shadow-soft: 0 18px 48px rgba(43, 27, 46, 0.08);
  --shadow-card: 0 22px 56px rgba(11, 11, 12, 0.07), 0 2px 6px rgba(11, 11, 12, 0.04);
  --shadow-hover: 0 28px 72px rgba(11, 11, 12, 0.12);
  --shadow-gold: 0 0 0 1px var(--hairline-gold), 0 18px 48px rgba(154, 123, 60, 0.12);
  --display: "Fraunces", Georgia, serif;
  --body: "Lato", ui-sans-serif, system-ui, sans-serif;
  --sans: "Inter", ui-sans-serif, system-ui, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  --script: "Pinyon Script", cursive;
  --wordmark: "Cormorant Garamond", "Newsreader", serif;
  --r-xs: 4px;
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-xl: 30px;
  --r-pill: 999px;
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 24px;
  --s-6: 32px;
  --s-7: 48px;
  --s-8: 64px;
  --s-9: 96px;
  --s-10: 128px;
  --s-11: 160px;
  --dur-instant: 80ms;
  --dur-fast: 140ms;
  --dur-base: 220ms;
  --dur-slow: 360ms;
  --dur-stately: 540ms;
  --ease-standard: cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-entry: cubic-bezier(0.16, 0.84, 0.44, 1);
  --ease-exit: cubic-bezier(0.4, 0, 0.84, 0.16);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --ring: 0 0 0 3px rgba(15, 61, 52, 0.25);
  --ring-gold: 0 0 0 3px rgba(200, 165, 94, 0.35);
  --ring-danger: 0 0 0 3px rgba(179, 71, 58, 0.25);
  --inspector: 380px;
  font-family: var(--body);
}

* { box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  overflow-x: clip;
}

body {
  margin: 0;
  min-height: 100vh;
  overflow-x: clip;
  background:
    radial-gradient(circle at 90% 2%, rgba(161, 132, 74, 0.16), transparent 30%),
    radial-gradient(circle at 4% 96%, rgba(15, 61, 52, 0.13), transparent 36%),
    radial-gradient(circle at 50% 50%, rgba(43, 27, 46, 0.04), transparent 60%),
    linear-gradient(180deg, rgba(250, 248, 243, 0.98), rgba(242, 237, 229, 0.78)),
    var(--bone);
  color: var(--ink);
  font-family: var(--body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: linear-gradient(rgba(11, 11, 12, 0.025) 1px, transparent 1px);
  background-size: 100% 80px;
  mask-image: linear-gradient(to bottom, black, transparent 80%);
}

button, input, select, textarea { font: inherit; color: inherit; }
button { -webkit-tap-highlight-color: transparent; cursor: pointer; }
a { color: inherit; text-decoration: none; }
svg { display: block; }
h1, h2, h3, h4, h5, p, ul { margin-top: 0; }

/* ───────── Ticker ───────── */
.ticker {
  position: relative;
  z-index: 40;
  width: 100%;
  max-width: 100vw;
  overflow: hidden;
  contain: paint;
  background: var(--ink);
  color: var(--bone);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.ticker-track {
  display: inline-flex;
  gap: 38px;
  padding: 10px 0;
  white-space: nowrap;
  animation: tickerScroll 60s linear infinite;
}
.ticker-track span {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  opacity: 0.86;
}
.ticker .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--champagne);
  display: inline-block;
}
.ticker .dot.pulse {
  background: #56e0a8;
  box-shadow: 0 0 0 0 rgba(86, 224, 168, 0.6);
  animation: pulse 1.8s ease-out infinite;
}
.ticker .arrow {
  display: inline-block;
  width: 8px; height: 8px;
  border-top: 2px solid var(--champagne);
  border-right: 2px solid var(--champagne);
}
.ticker .arrow.up { transform: rotate(-45deg); border-color: #56e0a8; }
.ticker .arrow.flat { transform: rotate(45deg); border-color: var(--mauve); border-right: 0; border-top: 2px solid var(--mauve); width: 12px; height: 0; }
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@keyframes pulse {
  0% { box-shadow: 0 0 0 0 rgba(86, 224, 168, 0.7); }
  70% { box-shadow: 0 0 0 10px rgba(86, 224, 168, 0); }
  100% { box-shadow: 0 0 0 0 rgba(86, 224, 168, 0); }
}

/* ───────── App shell ───────── */
.app-shell {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) var(--inspector);
  gap: 28px;
  width: min(1360px, calc(100% - 64px));
  margin: 0 auto;
  min-height: 100vh;
  /* Prevent the full-width sticky header (which uses negative margin to break
     out of this container) from triggering a horizontal scrollbar. */
  overflow-x: clip;
}

/* ───────── Sidebar / Top nav ───────── */
.sidebar {
  position: sticky;
  top: 0;
  z-index: 30;
  grid-column: 1 / -1;
  /* Break out of the .app-shell width cap so the header spans the full viewport,
     while the rest of the page content remains centered at 1360px max. */
  width: 100vw;
  margin-left: calc(-1 * (50vw - 50%));
  padding: 14px 32px;
  border-bottom: 1px solid var(--hairline);
  background: rgba(250, 248, 243, 0.92);
  backdrop-filter: blur(18px);
  display: grid;
  grid-template-columns: minmax(220px, auto) minmax(0, 1fr) minmax(230px, auto);
  gap: 24px;
  align-items: center;
}
.brand {
  display: inline-grid;
  grid-template-columns: 50px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  width: fit-content;
}
.brand-mark {
  width: 50px; height: 50px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(140deg, var(--ink), #1a1a1f 70%);
  box-shadow: 0 10px 24px rgba(11, 11, 12, 0.18);
  position: relative;
}
.brand-mark::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid var(--champagne);
  opacity: 0.4;
}
.brand-mark img { width: 50px; height: 50px; display: block; }
.brand-mark.sm { width: 32px; height: 32px; }
.brand-mark.sm img { width: 32px; height: 32px; }
.brand-text strong {
  display: block;
  margin-bottom: 2px;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.01em;
}
.brand-text em {
  display: block;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.74rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.product-brand {
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 18px;
}
.product-brand .brand-mark {
  width: 68px;
  height: 68px;
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.product-brand .brand-mark::after {
  display: none;
}
.product-brand .brand-mark img {
  width: 68px;
  height: 68px;
  object-fit: contain;
}
.product-brand .brand-text strong {
  margin-bottom: 5px;
  font-size: 1.55rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
}
.product-brand .brand-text em {
  max-width: 150px;
  font-size: 0.68rem;
}

/* Formal lockup variant — the new canonical homepage logo */
.product-brand--lockup {
  display: inline-flex;
  align-items: center;
  grid-template-columns: none;
  gap: 0;
  padding: 0;
  background: transparent;
  box-shadow: none;
}
.product-brand--lockup .brand-lockup {
  display: block;
  height: 56px;
  width: auto;
  max-width: 240px;
  object-fit: contain;
}
.footer-lockup {
  display: block;
  height: 48px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  margin-bottom: 14px;
}

.nav-list {
  display: flex;
  justify-content: center;
  gap: 4px;
  min-width: 0;
  padding: 4px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255, 255, 255, 0.72);
  overflow-x: auto;
  scrollbar-width: none;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6), 0 4px 14px rgba(11,11,12,0.04);
}
.nav-list::-webkit-scrollbar { display: none; }
.nav-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.83rem;
  font-weight: 700;
  white-space: nowrap;
  transition: color 180ms, background 180ms, border-color 180ms, transform 180ms;
}
.nav-item:hover {
  border-color: rgba(15, 61, 52, 0.18);
  background: rgba(15, 61, 52, 0.06);
  color: var(--forest);
}
.nav-item.active {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
  box-shadow: 0 6px 14px rgba(11,11,12,0.18);
}
.nav-icon { width: 16px; height: 16px; display: grid; place-items: center; color: currentColor; }
.nav-icon svg, .icon-button svg, .search-field svg {
  width: 16px; height: 16px;
  fill: none; stroke: currentColor;
  stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round;
}

.sidebar-note {
  justify-self: end;
  min-width: 0;
  padding: 10px 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(242, 237, 229, 0.84);
  color: var(--slate);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.sidebar-note .note-label {
  margin: 0;
  padding-right: 10px;
  border-right: 1px solid var(--hairline-strong);
}
.sidebar-note strong {
  display: inline-flex; align-items: center; gap: 6px;
  margin: 0;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 800;
}
.sidebar-note strong .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #56e0a8;
  box-shadow: 0 0 0 3px rgba(86, 224, 168, 0.18);
}
.sidebar-note p { display: none; }

/* ───────── Typography ───────── */
.note-label, .eyebrow {
  margin: 0 0 12px;
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.workspace { min-width: 0; padding: 40px 0 80px; }

.topbar {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(220px, 0.55fr);
  gap: 32px;
  align-items: end;
  margin: 12px 0 36px;
  padding: 36px 0 30px;
  border-bottom: 1px solid var(--hairline);
}
.masthead .hero-heading { min-width: 0; max-width: 820px; }
.product-lockup {
  display: inline-grid;
  grid-template-columns: 96px auto;
  gap: 24px;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 24px;
}
.product-lockup img {
  width: 96px;
  height: 96px;
  display: block;
  object-fit: cover;
  filter: drop-shadow(0 16px 28px rgba(11, 11, 12, 0.08));
}
.product-lockup strong {
  color: var(--ink);
  font-family: var(--sans);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1;
}
.site-footer .brand-mark.sm {
  border-radius: 50%;
  background: transparent;
  box-shadow: none;
  overflow: visible;
}
.site-footer .brand-mark.sm::after {
  display: none;
}
.topbar .eyebrow {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
  color: var(--slate);
}
.eyebrow .rule {
  width: 38px; height: 2px;
  border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--forest), var(--champagne));
  display: inline-block;
}

h1 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(3.1rem, 6.6vw, 5.8rem);
  font-weight: 300;
  line-height: 0.98;
  letter-spacing: 0;
  color: var(--ink);
}
h1 em {
  font-style: italic;
  font-weight: 400;
  color: var(--forest);
}
.hero-copy {
  max-width: 640px;
  margin: 20px 0 0;
  color: var(--slate);
  font-size: 1.04rem;
  line-height: 1.58;
}
.hero-cta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  margin-top: 26px;
}
.trust-line {
  flex-basis: 100%;
  margin-top: 6px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.02em;
}

h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(1.85rem, 2.6vw, 2.6rem);
  font-weight: 400;
  line-height: 1.06;
  letter-spacing: 0;
  color: var(--ink);
}
h2 em,
h3 em,
.section-sub em,
.hero-copy em,
.lede em {
  color: var(--forest);
  font-family: var(--display);
  font-style: italic;
  font-weight: 400;
}
h3 {
  margin: 0 0 10px;
  font-family: var(--sans);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  line-height: 1.22;
}
h4 {
  margin: 0 0 10px;
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink);
}
h5 {
  margin: 0 0 10px;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink);
}
.section-sub {
  max-width: 560px;
  margin-top: 6px;
  color: var(--slate);
  font-size: 0.94rem;
  line-height: 1.5;
}
.lede {
  max-width: 580px;
  margin: 14px 0 0;
  color: var(--slate);
  font-family: var(--display);
  font-style: italic;
  font-size: 1.05rem;
  line-height: 1.5;
}

/* ───────── Hero aside ───────── */
.hero-aside {
  display: grid;
  justify-items: end;
  gap: 22px;
  flex: 0 0 auto;
}
.hero-seal-wrap {
  position: relative;
  display: grid;
  place-items: center;
  width: clamp(140px, 13vw, 180px);
  height: clamp(140px, 13vw, 180px);
}
.hero-seal {
  width: 100%; height: 100%;
  display: block;
  filter: drop-shadow(0 22px 36px rgba(11, 11, 12, 0.18));
}
.seal-ring {
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 1px solid rgba(161, 132, 74, 0.4);
  animation: spinRing 28s linear infinite;
}
.seal-ring::before {
  content: "★";
  position: absolute;
  top: -8px; left: 50%;
  transform: translateX(-50%);
  color: var(--champagne);
  background: var(--bone);
  padding: 0 6px;
  font-size: 0.7rem;
}
@keyframes spinRing {
  to { transform: rotate(360deg); }
}
.top-actions {
  display: flex; align-items: center; gap: 10px;
}

/* ───────── Buttons ───────── */
.icon-button, .primary-action, .ghost-action, .text-action, .save-button, .source-button {
  min-height: 42px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 0 18px;
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  transition: transform var(--dur-fast) var(--ease-standard), border-color var(--dur-fast) var(--ease-standard), background var(--dur-fast) var(--ease-standard), box-shadow var(--dur-fast) var(--ease-standard), color var(--dur-fast) var(--ease-standard);
}
.icon-button { width: 42px; padding: 0; }
.primary-action {
  border-color: transparent;
  background: var(--ink);
  color: white;
  box-shadow: var(--elev-1);
}
.primary-action:hover {
  transform: translateY(-1px);
  background: var(--forest);
  box-shadow: var(--elev-2);
}
.primary-action.lg { min-height: 50px; padding: 0 26px; font-size: 0.92rem; }
.primary-action.sm { min-height: 34px; padding: 0 14px; font-size: 0.78rem; }
.ghost-action {
  background: transparent;
  border-color: var(--ink);
}
.ghost-action:hover { background: var(--ink); color: var(--bone); }
.ghost-action.lg { min-height: 50px; padding: 0 26px; font-size: 0.92rem; }
.ghost-action.sm { min-height: 34px; padding: 0 12px; font-size: 0.76rem; }
.ghost-action.block, .primary-action.block { display: flex; width: 100%; }
.text-action { padding: 0 14px; background: transparent; border-color: transparent; }
.text-action:hover { background: var(--paper); }
.save-button, .source-button { padding: 0 14px; font-size: 0.84rem; }
.source-button { border-color: var(--ink); background: var(--ink); color: var(--bone); }
.icon-button:hover, .text-action:hover, .save-button:hover, .source-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(43, 27, 46, 0.1);
}

/* ───────── Logo bar / social proof ───────── */
.logo-bar {
  display: flex;
  align-items: center;
  gap: 22px;
  margin-bottom: 28px;
  padding: 18px 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.7);
}
.logo-bar-label {
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}
.logo-bar ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 14px 28px;
}
.logo-bar li {
  position: relative;
  color: var(--ink-soft);
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: -0.005em;
  opacity: 0.78;
}
.logo-bar li::before {
  content: "•";
  position: absolute;
  left: -18px;
  color: var(--champagne);
}
.logo-bar li:first-child::before { display: none; }

/* ───────── Metrics ───────── */
.metrics-strip {
  display: grid;
  grid-template-columns: 1.2fr repeat(3, 1fr) 1.15fr;
  gap: 14px;
  margin-bottom: 28px;
}
.metric, .metrics-strip > div {
  position: relative;
  min-height: 138px;
  padding: 20px 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.88);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
}
.metric-hero {
  background: linear-gradient(155deg, #fff 60%, rgba(15,61,52,0.05));
  border-color: rgba(15,61,52,0.18);
}
.metric-hero::before {
  content: "";
  position: absolute;
  top: -30px; right: -30px;
  width: 120px; height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(15,61,52,0.16), transparent 70%);
}
.metric-trend {
  position: absolute;
  top: 16px; right: 18px;
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  padding: 3px 9px;
  border-radius: var(--r-pill);
}
.metric-trend.up { color: #15573d; background: rgba(21,87,61,0.1); }
.metric-trend.down { color: #8c2a2a; background: rgba(140,42,42,0.1); }
.metric-trend.flat { color: var(--slate); background: rgba(74,74,82,0.08); }

.metrics-strip span:not(.metric-trend):not(.signal-pulse):not(.signal-pulse *) {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(2rem, 2.6vw, 2.6rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.01em;
}
.metric .metric-num {
  display: block;
  margin-bottom: 8px;
  color: var(--ink);
  font-family: var(--display);
  font-size: 2.4rem;
  font-weight: 300;
  line-height: 1;
}
.metrics-strip p {
  margin: 0;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.metrics-strip small {
  display: block;
  margin-top: 6px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.72rem;
  letter-spacing: 0.02em;
}
.metric-signal {
  background: linear-gradient(140deg, var(--ink) 0%, #1a2c28 100%);
  color: var(--bone);
  border-color: var(--ink);
}
.metric-signal .metric-num { color: var(--bone); }
.metric-signal p { color: var(--bone); opacity: 0.95; }
.metric-signal small { color: rgba(250,248,243,0.62); }
.signal-pulse {
  position: absolute;
  top: 16px; right: 18px;
  display: inline-flex; gap: 4px;
}
.signal-pulse i {
  width: 6px; height: 6px; border-radius: 50%;
  background: #56e0a8;
  animation: blink 1.4s ease-in-out infinite;
}
.signal-pulse i:nth-child(2) { animation-delay: 0.2s; }
.signal-pulse i:nth-child(3) { animation-delay: 0.4s; }
@keyframes blink {
  0%, 100% { opacity: 0.2; transform: scale(0.8); }
  50% { opacity: 1; transform: scale(1.1); }
}

/* ───────── Search ───────── */
.search-panel {
  margin-bottom: 36px;
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.84);
  box-shadow: var(--shadow-card);
}
.search-row {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}
.search-field {
  position: relative;
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  min-height: 54px;
  padding: 0 18px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: white;
  color: var(--mauve);
  transition: border-color 180ms, box-shadow 180ms;
}
.search-field:focus-within {
  border-color: var(--forest);
  box-shadow: 0 0 0 4px rgba(15,61,52,0.08);
}
.search-field input {
  width: 100%; min-width: 0;
  border: 0; outline: 0;
  background: transparent;
  color: var(--ink);
  font-size: 0.95rem;
}
.search-field input::placeholder { color: rgba(74, 74, 82, 0.6); }
.key-hint {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--slate);
  padding: 3px 7px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  background: var(--paper);
}
.search-quicks {
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: flex-end;
}
.search-quicks button {
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.62);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 700;
  transition: all 180ms;
}
.search-quicks button:hover {
  border-color: var(--forest);
  color: var(--forest);
  background: rgba(15,61,52,0.06);
}

.filter-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}
.filter-grid label {
  display: grid; gap: 7px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.filter-grid select {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  padding: 0 12px;
  background: white;
  color: var(--ink);
  transition: border-color 180ms;
}
.filter-grid select:focus { border-color: var(--forest); outline: 0; }

/* ───────── Views ───────── */
.view-panel { display: none; animation: viewIn 240ms ease both; }
.view-panel.active { display: block; }
@keyframes viewIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.section-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 18px;
  margin: 8px 0 22px;
}
.result-count {
  margin: 0;
  padding: 6px 12px;
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}

/* ───────── Opportunity rows ───────── */
.opportunity-list { display: grid; gap: 10px; }
.opportunity-row {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) 130px 180px 120px;
  gap: 18px;
  align-items: center;
  width: 100%;
  min-height: 108px;
  padding: 18px 22px;
  border: 1px solid var(--hairline);
  border-left: 4px solid var(--champagne);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ink);
  text-align: left;
  cursor: pointer;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms, background 200ms;
}
.opportunity-row::after {
  content: "→";
  position: absolute;
  right: 24px; top: 50%;
  transform: translateY(-50%) translateX(-6px);
  color: var(--champagne);
  font-family: var(--sans);
  font-size: 1.2rem;
  opacity: 0;
  transition: opacity 200ms, transform 200ms;
}
.opportunity-row:hover, .opportunity-row.selected {
  transform: translateY(-2px);
  border-color: rgba(15, 61, 52, 0.32);
  background: white;
  box-shadow: var(--shadow-hover);
}
.opportunity-row:hover::after, .opportunity-row.selected::after {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}
.compact .opportunity-row { min-height: 78px; padding: 13px 18px; }
.row-title { min-width: 0; }
.row-title strong {
  display: block;
  margin-bottom: 7px;
  font-family: var(--display);
  font-size: 1.12rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.22;
  color: var(--ink);
}
.row-title span, .row-cell span {
  display: block;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  line-height: 1.36;
}
.row-cell { min-width: 0; }
.row-cell b {
  display: block;
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.28;
  color: var(--ink);
  overflow-wrap: anywhere;
}
.row-cell span {
  text-transform: uppercase;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: var(--champagne-deep);
  margin-bottom: 4px;
}

.badge-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 3px 9px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: var(--surface);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.badge .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge-live { color: var(--signal-up); border-color: rgba(31, 138, 91, 0.3); background: var(--signal-up-soft); }
.badge-beta { color: var(--champagne-deep); border-color: rgba(154, 123, 60, 0.35); background: var(--champagne-soft); }
.badge-new { color: var(--forest); border-color: rgba(15, 61, 52, 0.3); background: rgba(15, 61, 52, 0.06); }
.badge-watch { color: var(--signal-watch); border-color: rgba(198, 154, 62, 0.4); background: var(--signal-watch-soft); }
.badge-closed { color: var(--slate); border-color: var(--hairline-strong); background: var(--paper); }
.badge-info { color: var(--signal-info); border-color: rgba(44, 94, 156, 0.35); background: var(--signal-info-soft); }
.badge.garnet { background: rgba(161, 132, 74, 0.14); color: #715928; }
.badge.sage { background: rgba(107, 128, 115, 0.14); color: #435b4d; }
.badge.teal { background: rgba(15, 61, 52, 0.1); color: var(--forest); }
.badge.relevance { background: var(--ink); color: var(--bone); }
.badge.verification { background: rgba(11,11,12,0.07); color: var(--slate); }
.badge.verification.verified { background: rgba(15,61,52,0.12); color: var(--forest-deep); }
.badge.verification.seeded { background: rgba(161,132,74,0.16); color: var(--champagne-deep); }
.badge.verification.needs-review { background: rgba(120,67,81,0.14); color: var(--mauve); }
.badge.verification.archived { background: rgba(11,11,12,0.12); color: var(--slate); }

.deadline-countdown {
  font-variant-numeric: tabular-nums;
}
.deadline-countdown.today,
.status-value.closing-today {
  color: #8c2a2a;
}
.deadline-countdown.soon,
.status-value.closing-soon {
  color: var(--champagne-deep);
}
.deadline-countdown.watch {
  color: var(--forest);
}
.deadline-countdown.closed,
.status-value.closed {
  color: var(--slate);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.badge.status-badge {
  border-color: rgba(11, 11, 12, 0.08);
}
.badge.status-badge.open {
  background: rgba(15, 61, 52, 0.1);
  color: var(--forest);
}
.badge.status-badge.closing-today {
  background: rgba(140, 42, 42, 0.1);
  color: #8c2a2a;
}
.badge.status-badge.closing-soon {
  background: rgba(161, 132, 74, 0.17);
  color: var(--champagne-deep);
}
.badge.status-badge.closed {
  background: rgba(74, 74, 82, 0.1);
  color: var(--slate);
}
.badge.status-badge.forecasted,
.badge.status-badge.opening-soon {
  background: rgba(59, 42, 66, 0.12);
  color: var(--plum);
}
.badge.status-badge.rolling,
.badge.status-badge.monitor {
  background: rgba(107, 128, 115, 0.14);
  color: #435b4d;
}

.empty-state {
  padding: 32px;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.78);
  color: var(--slate);
  line-height: 1.5;
}

/* ───────── Inspector ───────── */
.inspector {
  position: sticky;
  top: 90px;
  height: calc(100vh - 110px);
  padding: 40px 0 64px;
}
.inspector-inner {
  height: 100%;
  overflow-y: auto;
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-card);
}
.inspector-inner::-webkit-scrollbar { width: 6px; }
.inspector-inner::-webkit-scrollbar-thumb {
  background: var(--hairline-strong);
  border-radius: var(--r-pill);
}
.detail-kicker { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 16px; }
.detail-title {
  margin-bottom: 14px;
  font-family: var(--display);
  font-size: 1.85rem;
  font-weight: 400;
  line-height: 1.08;
  letter-spacing: -0.012em;
}
.detail-summary { color: var(--slate); font-size: 0.98rem; line-height: 1.58; }
.detail-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin: 20px 0;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: var(--hairline);
  overflow: hidden;
}
.detail-meta div { padding: 14px; background: white; }
.detail-meta span {
  display: block;
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.detail-meta b {
  display: block;
  margin-top: 7px;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.88rem;
  line-height: 1.32;
}
.detail-block { padding: 18px 0; border-top: 1px solid var(--hairline); }
.detail-block h3 { margin-bottom: 10px; color: var(--ink); }
.detail-block p, .detail-block li { color: var(--slate); line-height: 1.55; }
.detail-block ul { margin: 0; padding-left: 18px; }
.detail-actions { display: flex; gap: 8px; margin-top: 20px; flex-wrap: wrap; }

/* ───────── Alerts ───────── */
.alert-builder {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr;
  gap: 14px;
}
.alert-column, .alert-preview, .donor-card, .map-panel {
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: var(--shadow-card);
}
.alert-column, .alert-preview { padding: 24px; }
.checkbox-grid { display: grid; gap: 8px; }
.check-row {
  display: flex; align-items: center; gap: 10px;
  min-height: 34px;
  color: var(--slate);
  line-height: 1.25;
}
.check-row input { width: 16px; height: 16px; accent-color: var(--forest); }
.alert-preview {
  background:
    radial-gradient(circle at 80% 12%, rgba(161,132,74,0.18), transparent 50%),
    linear-gradient(140deg, var(--ink) 0%, var(--forest-deep) 70%);
  color: white;
  border-color: transparent;
}
.alert-preview .note-label { color: rgba(255,255,255,0.66); }
.alert-preview h3 { color: white; font-family: var(--display); font-size: 1.2rem; font-weight: 500; }
.alert-preview p { color: rgba(255,255,255,0.78); line-height: 1.5; }
.alert-matches { display: grid; gap: 8px; margin-top: 18px; }
.match-item {
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: var(--r-sm);
  background: rgba(255, 255, 255, 0.08);
}
.match-item strong { display: block; font-family: var(--sans); font-size: 0.88rem; font-weight: 800; }
.match-item span { display: block; margin-top: 4px; color: rgba(255,255,255,0.72); font-size: 0.78rem; }
.alert-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.alert-save {
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--r-pill);
  background: white;
  color: var(--forest-deep);
  padding: 10px 13px;
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 800;
  cursor: pointer;
}
.alert-save:disabled { opacity: 0.58; cursor: wait; }
.alert-actions span {
  color: rgba(255, 255, 255, 0.72);
  font-family: var(--sans);
  font-size: 0.76rem;
  line-height: 1.35;
}

/* ───────── Donors ───────── */
.donor-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.donor-card {
  padding: 22px;
  transition: transform 200ms, box-shadow 200ms;
}
.donor-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-hover); }
.donor-card strong {
  display: block;
  font-family: var(--display);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.16;
}
.donor-card p { margin: 12px 0 16px; color: var(--slate); line-height: 1.5; }
.donor-card dl { display: grid; gap: 10px; margin: 0; }
.donor-card dt {
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.donor-card dd { margin: 4px 0 0; color: var(--slate); line-height: 1.4; }

/* ───────── Map ───────── */
.map-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.6fr);
  gap: 1px;
  overflow: hidden;
  background: var(--hairline);
}
.map-canvas {
  min-height: 460px;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 24%, rgba(161, 132, 74, 0.14), transparent 22%),
    radial-gradient(circle at 76% 42%, rgba(15, 61, 52, 0.14), transparent 21%),
    radial-gradient(circle at 54% 68%, rgba(107, 128, 115, 0.12), transparent 25%),
    rgba(250, 248, 243, 0.96);
}
.map-region {
  position: absolute;
  width: clamp(128px, 18vw, 220px);
  padding: 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 14px 32px rgba(43, 27, 46, 0.12);
  color: var(--ink);
  text-align: left;
  cursor: pointer;
  transition: transform 200ms, border-color 200ms;
}
.map-region:hover { transform: translateY(-3px); border-color: rgba(15, 61, 52, 0.32); }
.map-region strong { display: block; font-family: var(--sans); font-weight: 800; }
.map-region span { display: block; margin-top: 4px; color: var(--slate); font-size: 0.8rem; }
.region-stack { padding: 18px; background: rgba(255, 255, 255, 0.96); }
.region-stat { display: flex; justify-content: space-between; gap: 14px; padding: 13px 0; border-bottom: 1px solid var(--hairline); }
.region-stat:last-child { border-bottom: 0; }
.region-stat strong { display: block; font-family: var(--sans); font-weight: 800; }
.region-stat span { color: var(--slate); font-size: 0.84rem; }

/* ═════════════════════════════════════════════════════════════════════
   ELITE UPGRADES (public index.html)
   ═════════════════════════════════════════════════════════════════════ */

/* ───── Elite masthead ───── */
.elite-masthead { padding-bottom: 42px; position: relative; }
.masthead-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(220px, 0.55fr);
  gap: 32px;
  align-items: end;
}
.kinetic-h1 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(3.1rem, 6.8vw, 6rem);
  font-weight: 300;
  line-height: 0.98;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.kinetic-h1 .kw { display: inline-block; margin-right: 0.3em; }
.kinetic-h1 em {
  font-style: italic;
  font-weight: 400;
  background: linear-gradient(95deg, var(--forest-deep), var(--champagne-deep) 90%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 36px;
  padding-top: 26px;
  border-top: 1px solid var(--hairline);
}
.hero-stats > div { display: flex; flex-direction: column; gap: 4px; }
.hero-stats strong {
  font-family: var(--display);
  font-size: clamp(1.7rem, 2.4vw, 2.4rem);
  font-weight: 300;
  letter-spacing: -0.012em;
  line-height: 1;
  color: var(--ink);
}
.hero-stats span {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}

.seal-ring.outer {
  inset: -14px;
  border-color: rgba(15, 61, 52, 0.18);
  animation-duration: 60s;
  animation-direction: reverse;
}
.hero-meta {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 18px;
  padding: 12px 16px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.6);
}
.hero-meta-row {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--sans);
  font-size: 0.74rem;
  color: var(--slate);
}
.hero-meta-row .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--champagne);
  display: inline-block;
}
.hero-meta-row .dot.pulse {
  background: #56e0a8;
  box-shadow: 0 0 0 0 rgba(86, 224, 168, 0.6);
  animation: pulse 1.8s ease-out infinite;
}

.scroll-cue {
  position: absolute;
  left: 50%; bottom: 8px;
  transform: translateX(-50%);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.8);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: all 200ms;
}
.scroll-cue svg { animation: scrollBob 2.2s ease-in-out infinite; }
.scroll-cue:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }
@keyframes scrollBob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(3px); }
}

/* ───── Press strip (replaces logo bar) ───── */
.press-strip {
  display: flex;
  align-items: center;
  gap: 28px;
  margin-bottom: 32px;
  padding: 22px 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background:
    linear-gradient(135deg, rgba(15,61,52,0.04), rgba(161,132,74,0.03)),
    rgba(255,255,255,0.78);
}
.press-label {
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}
.press-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px 28px;
}
.press-list li {
  position: relative;
  font-family: var(--display);
  font-size: 1.15rem;
  font-weight: 400;
  color: var(--ink);
  opacity: 0.82;
  letter-spacing: -0.005em;
  transition: opacity 200ms;
}
.press-list li:hover { opacity: 1; }
.press-list li::after {
  content: "";
  display: block;
  height: 1px;
  margin-top: 2px;
  background: linear-gradient(90deg, var(--champagne), transparent);
  opacity: 0;
  transition: opacity 200ms;
}
.press-list li:hover::after { opacity: 0.6; }

/* ───── Today on the desk · live feed ───── */
.desk-feed {
  margin-bottom: 36px;
  padding: 28px 32px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 100% 0%, rgba(15,61,52,0.06), transparent 50%),
    rgba(255,255,255,0.78);
  box-shadow: var(--shadow-card);
}
.feed-head {
  display: flex; justify-content: space-between; align-items: end;
  gap: 16px;
  margin-bottom: 18px;
}
.feed-head h2 {
  font-family: var(--display);
  font-size: clamp(1.5rem, 2vw, 2rem);
  font-weight: 400;
  letter-spacing: -0.012em;
}
.feed-legend {
  display: flex; gap: 14px; flex-wrap: wrap;
}
.feed-legend span {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--slate);
  padding: 5px 11px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.6);
}
.feed-legend .dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  display: inline-block;
}
.feed-legend .dot { background: #56e0a8; }
.feed-legend .dot.champ { background: var(--champagne); }
.feed-legend .dot.ink { background: var(--ink); }
.feed-legend .dot.pulse {
  box-shadow: 0 0 0 0 rgba(86,224,168,0.6);
  animation: pulse 1.8s ease-out infinite;
}

.feed-stream {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 8px;
}
.feed-item {
  position: relative;
  display: grid;
  grid-template-columns: 90px 150px minmax(0, 1fr) 10px;
  gap: 18px;
  align-items: center;
  padding: 12px 16px;
  border: 1px solid var(--hairline);
  border-left: 3px solid var(--champagne);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.94);
  transition: background 200ms, border-color 200ms;
}
.feed-item:hover { background: white; border-left-color: var(--forest); }
.feed-item[data-kind="trust"] { border-left-color: var(--ink); }
.feed-item[data-kind="editorial"] { border-left-color: var(--champagne); }
.feed-item[data-kind="match"] { border-left-color: var(--forest-glow); }
.feed-time {
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--slate);
}
.feed-source {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.feed-text {
  font-family: var(--body);
  font-size: 0.94rem;
  line-height: 1.42;
  color: var(--ink);
}
.feed-text b { font-weight: 700; color: var(--ink); }
.feed-text em { font-style: italic; color: var(--forest-deep); font-family: var(--display); }
.feed-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--champagne);
  align-self: center;
  justify-self: end;
}
.feed-dot.live {
  background: #56e0a8;
  box-shadow: 0 0 0 0 rgba(86,224,168,0.6);
  animation: pulse 1.8s ease-out infinite;
}
.feed-dot.champ { background: var(--champagne); }
.feed-dot.ink { background: var(--ink); }
.feed-dot.flash { animation: flashDot 1s ease-out 1; }
@keyframes flashDot {
  0% { box-shadow: 0 0 0 0 rgba(86,224,168,0.8); transform: scale(1.6); }
  100% { box-shadow: 0 0 0 12px rgba(86,224,168,0); transform: scale(1); }
}

/* ───── Bento · how the desk works ───── */
.bento-how {
  margin: 0 0 36px;
}
.bento-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-auto-rows: minmax(180px, auto);
  gap: 12px;
}
.bento {
  position: relative;
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.92);
  display: flex; flex-direction: column; gap: 10px;
  grid-column: span 2;
  overflow: hidden;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.bento:hover {
  transform: translateY(-3px);
  border-color: rgba(15,61,52,0.28);
  box-shadow: var(--shadow-hover);
}
.bento-lg { grid-column: span 3; }
.bento-step {
  font-family: var(--mono);
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--champagne-deep);
  letter-spacing: 0.1em;
}
.bento h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(1.15rem, 1.6vw, 1.4rem);
  font-weight: 500;
  letter-spacing: -0.005em;
  text-transform: none;
  color: var(--ink);
  line-height: 1.18;
}
.bento p { margin: 0; color: var(--slate); font-size: 0.92rem; line-height: 1.5; flex-grow: 1; }
.bento-stat {
  display: flex; align-items: baseline; gap: 10px;
  margin-top: 6px;
  padding-top: 12px;
  border-top: 1px dashed var(--hairline);
}
.bento-stat b {
  font-family: var(--display);
  font-size: 1.8rem;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.bento-stat span {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}
.bento-dark {
  background: linear-gradient(150deg, var(--ink) 0%, var(--forest-deep) 100%);
  color: var(--bone);
  border-color: transparent;
}
.bento-dark h3 { color: var(--bone); }
.bento-dark p { color: rgba(250,248,243,0.82); }
.bento-dark .bento-step { color: var(--champagne); }
.bento-dark .bento-stat { border-top-color: rgba(255,255,255,0.18); }
.bento-dark .bento-stat b { color: var(--bone); }
.bento-dark .bento-stat span { color: rgba(250,248,243,0.7); }

/* ───── Map upgrades · bespoke SVG world map ───── */
.map-panel-elite .map-canvas {
  min-height: 520px;
  position: relative;
  background: rgba(250, 248, 243, 0.96);
  overflow: hidden;
}
.world-svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.world-svg .continents path {
  transition: stroke 200ms;
}
.node-label {
  font-family: var(--sans);
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  fill: var(--ink);
  opacity: 0.78;
}
.pulse-ring {
  fill: none;
  stroke: var(--champagne);
  stroke-width: 1.2;
  opacity: 0;
  animation: worldPulse 3.4s ease-out infinite;
  transform-origin: center;
}
.delay-1 { animation-delay: 0.5s; }
.delay-2 { animation-delay: 1.0s; }
.delay-3 { animation-delay: 1.5s; }
.delay-4 { animation-delay: 2.0s; }
.delay-5 { animation-delay: 2.5s; }
.node-2 .pulse-ring, .node-4 .pulse-ring, .node-6 .pulse-ring { stroke: var(--forest-glow); }
@keyframes worldPulse {
  0% { transform: scale(1); opacity: 0.9; }
  100% { transform: scale(5); opacity: 0; }
}
.map-canvas .map-region {
  position: relative;
  z-index: 1;
}
.map-legend {
  display: flex; gap: 14px; flex-wrap: wrap;
}
.map-legend span {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--slate);
}
.map-legend .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--champagne);
}
.map-legend .dot.pulse {
  background: var(--champagne);
  box-shadow: 0 0 0 0 rgba(161,132,74,0.5);
  animation: pulse 1.8s ease-out infinite;
}
.map-legend .dot.champ { background: var(--champagne); }

/* ───── Built for · audience bento ───── */
.built-for {
  margin: 36px 0;
}
.audience-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}
.audience-card {
  display: flex; flex-direction: column; gap: 12px;
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
  position: relative;
  overflow: hidden;
}
.audience-card:hover {
  transform: translateY(-3px);
  border-color: rgba(15,61,52,0.32);
  box-shadow: var(--shadow-hover);
}
.audience-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(161,132,74,0.06), transparent 60%);
  opacity: 0;
  transition: opacity 200ms;
  pointer-events: none;
}
.audience-card:hover::after { opacity: 1; }
.audience-card header { display: flex; justify-content: space-between; align-items: center; }
.audience-icon {
  display: inline-grid; place-items: center;
  width: 38px; height: 38px;
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--champagne-deep);
  font-size: 1.1rem;
}
.audience-tag {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--slate);
}
.audience-card h3 {
  font-family: var(--display);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: -0.008em;
  text-transform: none;
  color: var(--ink);
  line-height: 1.18;
}
.audience-card > p { margin: 0; color: var(--slate); font-size: 0.92rem; line-height: 1.5; }
.audience-bullets {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 7px;
}
.audience-bullets li {
  position: relative;
  padding-left: 18px;
  color: var(--ink);
  font-size: 0.86rem;
  line-height: 1.45;
}
.audience-bullets li::before {
  content: "✓";
  position: absolute;
  left: 0; top: 0;
  color: var(--forest);
  font-weight: 800;
}
.audience-card .ghost-action { margin-top: auto; align-self: flex-start; }
.audience-card.foundation { border-top: 3px solid var(--forest); }
.audience-card.founder { border-top: 3px solid var(--champagne); }
.audience-card.accelerator { border-top: 3px solid var(--plum); }
.audience-card.funder { border-top: 3px solid var(--ink); background: linear-gradient(165deg, rgba(11,11,12,0.04), rgba(255,255,255,0.96)); }

/* ───── Capital flow Sankey · proportional · v2 ───── */
.capital-flow { margin: 36px 0; }
.capital-flow .section-head {
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 18px;
}
.flow-legend {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}
.flow-legend li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.7);
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 700;
  color: var(--slate);
  white-space: nowrap;
}
.flow-legend i {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  display: inline-block;
  box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

.flow-card {
  padding: 36px 36px 28px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,248,243,0.92));
  box-shadow: var(--shadow-card);
}
.flow-svg {
  width: 100%;
  height: auto;
  display: block;
  max-width: 100%;
}
/* Subtle interactive lift on hover for individual flow ribbons */
.flow-paths-left path,
.flow-paths-right path {
  transition: opacity 200ms ease, filter 200ms ease;
  cursor: pointer;
}
.flow-paths-left:hover path,
.flow-paths-right:hover path {
  opacity: 0.35;
}
.flow-paths-left path:hover,
.flow-paths-right path:hover {
  opacity: 1 !important;
  filter: brightness(1.08) saturate(1.1);
}

/* In-flow $ badges — text-shadow gives them readability over gradient bands */
.flow-labels text {
  paint-order: stroke;
  stroke: rgba(250,248,243,0.92);
  stroke-width: 3px;
  stroke-linejoin: round;
}

.flow-foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--hairline);
  flex-wrap: wrap;
  gap: 16px;
}
.flow-foot-stats {
  display: flex;
  gap: 36px;
  flex-wrap: wrap;
}
.flow-foot-stats > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.flow-foot-stats b {
  font-family: var(--display);
  font-size: 1.7rem;
  font-weight: 300;
  color: var(--ink);
  letter-spacing: -0.012em;
  line-height: 1;
}
.flow-foot-stats span {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}

@media (max-width: 900px) {
  .flow-card { padding: 20px; }
  .flow-foot { flex-direction: column; align-items: flex-start; }
  .flow-foot-stats { gap: 20px; }
  .flow-foot-stats b { font-size: 1.4rem; }
}

/* ───── Methodology · editorial ───── */
.methodology { margin: 36px 0; }
.method-grid {
  display: grid;
  grid-template-columns: minmax(260px, 0.42fr) minmax(0, 1fr);
  gap: 32px;
  padding: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    linear-gradient(150deg, rgba(15,61,52,0.04), transparent 60%),
    rgba(255,255,255,0.86);
  box-shadow: var(--shadow-card);
}
.method-side h2 { font-size: clamp(1.6rem, 2.2vw, 2.2rem); margin-bottom: 12px; }
.method-lede {
  margin: 0 0 24px;
  font-family: var(--display);
  font-style: italic;
  font-size: 1.1rem;
  color: var(--slate);
}
.method-marks { display: grid; gap: 8px; }
.method-marks span {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.7);
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink);
}
.method-marks i {
  font-style: normal;
  color: var(--champagne);
  font-size: 0.86rem;
}

.method-body p {
  font-family: var(--display);
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--ink);
  margin-bottom: 22px;
}
.dropcap .dc {
  float: left;
  font-family: var(--display);
  font-size: 4.2rem;
  font-weight: 400;
  line-height: 0.86;
  margin: 0 12px 0 0;
  padding-top: 4px;
  color: var(--forest-deep);
  letter-spacing: -0.02em;
}
.method-principles {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 16px;
}
.method-principles li {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 16px;
  padding: 16px 0;
  border-top: 1px solid var(--hairline);
}
.method-principles li:first-child { border-top: 0; padding-top: 0; }
.m-num {
  font-family: var(--display);
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--champagne-deep);
  letter-spacing: -0.01em;
}
.method-principles h4 {
  margin: 0 0 6px;
  font-family: var(--display);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  text-transform: none;
  color: var(--ink);
}
.method-principles p {
  font-family: var(--body);
  font-size: 0.94rem;
  line-height: 1.5;
  color: var(--slate);
  margin: 0;
}

/* ───── Comparison table ───── */
.comparison { margin: 36px 0; }
.compare-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-card);
}
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--sans);
  font-size: 0.92rem;
}
.compare-table thead { background: var(--paper); }
.compare-table th {
  padding: 18px 22px;
  text-align: left;
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: -0.005em;
  color: var(--ink);
  border-bottom: 1px solid var(--hairline-strong);
  vertical-align: bottom;
}
.compare-table thead th:first-child { background: rgba(11,11,12,0.04); }
.compare-table thead th.us {
  background: linear-gradient(180deg, var(--ink), var(--forest-deep));
  color: var(--bone);
}
.compare-table small {
  display: block;
  margin-top: 4px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 500;
}
.compare-table thead th.us small { color: rgba(250,248,243,0.7); }
.compare-table tbody th {
  padding: 16px 22px;
  font-family: var(--sans);
  font-weight: 800;
  font-size: 0.86rem;
  color: var(--ink);
  border-bottom: 1px solid var(--hairline);
  background: rgba(11,11,12,0.02);
  border-right: 1px solid var(--hairline);
}
.compare-table td {
  padding: 16px 22px;
  border-bottom: 1px solid var(--hairline);
  color: var(--slate);
}
.compare-table td.us {
  background: rgba(15,61,52,0.04);
  border-left: 1px solid rgba(15,61,52,0.15);
  border-right: 1px solid rgba(15,61,52,0.15);
}
.compare-table td.us b { color: var(--forest-deep); font-weight: 800; }
.compare-table tbody tr:last-child td, .compare-table tbody tr:last-child th { border-bottom: 0; }
.compare-table td.warn { color: var(--champagne-deep); }
.compare-table td.no { color: var(--mauve); font-style: italic; }

/* ───── Pricing toggle ───── */
.bill-toggle {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.7);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6);
}
.bt-opt {
  padding: 9px 18px;
  border: 0;
  border-radius: var(--r-pill);
  background: transparent;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  transition: all 200ms;
  display: inline-flex; align-items: center; gap: 8px;
}
.bt-opt:hover { color: var(--ink); }
.bt-opt.active {
  background: var(--ink);
  color: var(--bone);
  box-shadow: 0 6px 16px rgba(11,11,12,0.2);
}
.bt-opt .save {
  font-family: var(--mono);
  font-size: 0.66rem;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: var(--champagne);
  color: var(--ink);
  font-weight: 800;
  letter-spacing: 0.04em;
}
.bt-opt.active .save { background: var(--champagne); color: var(--ink); }

/* ───── FAQ ───── */
.faq { margin: 36px 0; }
.faq-list {
  display: grid; gap: 8px;
}
.faq-item {
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.92);
  padding: 0;
  overflow: hidden;
  transition: border-color 200ms, box-shadow 200ms;
}
.faq-item:hover { border-color: rgba(15,61,52,0.28); }
.faq-item[open] { box-shadow: var(--shadow-card); border-color: rgba(15,61,52,0.32); }
.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px;
  font-family: var(--display);
  font-size: clamp(1.05rem, 1.3vw, 1.2rem);
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-icon {
  width: 24px; height: 24px;
  position: relative;
  flex-shrink: 0;
}
.faq-icon::before, .faq-icon::after {
  content: "";
  position: absolute;
  background: var(--ink);
  border-radius: 2px;
}
.faq-icon::before { top: 50%; left: 0; right: 0; height: 2px; transform: translateY(-50%); }
.faq-icon::after { left: 50%; top: 0; bottom: 0; width: 2px; transform: translateX(-50%); transition: transform 200ms; }
.faq-item[open] .faq-icon::after { transform: translateX(-50%) rotate(90deg); opacity: 0; }
.faq-item p {
  padding: 0 26px 26px;
  margin: 0;
  color: var(--slate);
  font-family: var(--body);
  font-size: 0.96rem;
  line-height: 1.62;
  max-width: 820px;
}

/* ───── Founder's note ───── */
.founder-note { margin: 36px 0; }
.founder-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.6fr);
  gap: 32px;
  padding: 40px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 95% 5%, rgba(161,132,74,0.12), transparent 50%),
    rgba(255,255,255,0.86);
  box-shadow: var(--shadow-card);
}
.founder-left .eyebrow { margin-bottom: 18px; }
.founder-pull {
  font-family: var(--display);
  font-size: clamp(1.3rem, 1.9vw, 1.7rem);
  font-weight: 400;
  font-style: italic;
  line-height: 1.4;
  letter-spacing: -0.008em;
  color: var(--ink);
  margin-bottom: 24px;
}
.founder-left p {
  font-family: var(--body);
  font-size: 1rem;
  line-height: 1.62;
  color: var(--slate);
  margin-bottom: 14px;
}
.founder-sign {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px solid var(--hairline);
}
.sig strong {
  display: block;
  font-family: var(--display);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.sig em { font-style: normal; color: var(--slate); font-family: var(--sans); font-size: 0.82rem; }
.sig-mark {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--champagne), var(--champagne-deep));
  color: var(--ink);
  font-size: 1.6rem;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(161,132,74,0.32);
}
.founder-right {
  padding: 26px;
  border-radius: var(--r-lg);
  background: linear-gradient(150deg, var(--ink), var(--forest-deep));
  color: var(--bone);
  display: flex; flex-direction: column; gap: 12px;
  justify-content: center;
}
.founder-right header { display: flex; justify-content: flex-start; }
.founder-tag {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  background: var(--champagne);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.founder-right h3 {
  font-family: var(--display);
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  text-transform: none;
  color: var(--bone);
  margin: 0;
}
.founder-right p { margin: 0; color: rgba(250,248,243,0.82); font-size: 0.96rem; line-height: 1.55; }
.founder-right .primary-action { margin-top: 8px; align-self: stretch; }

/* ───── Responsive ───── */
@media (max-width: 1280px) {
  .bento-grid { grid-template-columns: repeat(4, 1fr); }
  .bento, .bento-lg { grid-column: span 2; }
  .audience-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 1180px) {
  .masthead-grid { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: repeat(4, 1fr); }
  .method-grid { grid-template-columns: 1fr; padding: 28px; }
  .founder-grid { grid-template-columns: 1fr; padding: 28px; }
}
@media (max-width: 900px) {
  .bento-grid { grid-template-columns: 1fr 1fr; }
  .bento, .bento-lg { grid-column: span 1; }
  .audience-grid { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: 1fr 1fr; gap: 18px; }
  .feed-item { grid-template-columns: 1fr; gap: 6px; padding: 14px; }
  .feed-dot { justify-self: flex-start; }
  .feed-head { flex-direction: column; align-items: flex-start; }
  .desk-feed, .flow-card { padding: 20px; }
  .compare-table th, .compare-table td { padding: 12px 14px; font-size: 0.84rem; }
  .scroll-cue { position: relative; left: auto; bottom: auto; transform: none; margin-top: 18px; display: inline-flex; }
  .press-list li { font-size: 0.98rem; }
  .map-panel-elite .map-canvas { min-height: 600px; }
}

/* ═════════════════════════════════════════════════════════════════════
   SHARED INTERACTIVE UI · modals · toasts · forms · activity
   Used by donor portal AND founder portal
   ═════════════════════════════════════════════════════════════════════ */

/* ── Modal ── */
.dd-modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(11, 11, 12, 0.55);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 40px 24px;
  animation: ddFadeIn 200ms ease;
}
@keyframes ddFadeIn { from { opacity: 0 } to { opacity: 1 } }
.dd-modal {
  position: relative;
  width: 100%; max-width: 640px; max-height: 90vh;
  overflow-y: auto;
  padding: 36px 40px;
  border-radius: 22px;
  background: var(--bone);
  box-shadow: 0 40px 100px rgba(11,11,12,0.32), 0 4px 16px rgba(11,11,12,0.12);
  animation: ddSlideUp 240ms cubic-bezier(.2,.7,.2,1);
}
.dd-modal.wide { max-width: 880px; }
@keyframes ddSlideUp {
  from { opacity: 0; transform: translateY(20px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.dd-modal-close {
  position: absolute; top: 16px; right: 16px;
  width: 36px; height: 36px;
  border: 0; border-radius: 50%;
  background: rgba(11,11,12,0.08);
  color: var(--ink);
  font-size: 1.4rem; line-height: 1;
  cursor: pointer;
  transition: background 180ms, transform 180ms;
}
.dd-modal-close:hover { background: var(--ink); color: var(--bone); transform: rotate(90deg); }
body.dd-modal-open { overflow: hidden; }

.dd-modal-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--hairline);
  margin-bottom: 18px;
}
.dd-modal-title {
  font-family: var(--display); font-size: 1.8rem; font-weight: 500;
  letter-spacing: -0.012em; line-height: 1.16; color: var(--ink);
  margin: 0 0 4px;
}
.dd-modal-sub { margin: 0; color: var(--slate); font-size: 0.92rem; line-height: 1.4; }
.dd-h3 {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  margin: 22px 0 10px;
}
.dd-body {
  font-family: var(--display); font-size: 1rem; line-height: 1.6; color: var(--ink);
  margin: 0 0 14px;
}
.dd-modal-foot {
  display: flex; gap: 10px; justify-content: flex-end;
  margin-top: 22px; padding-top: 18px;
  border-top: 1px solid var(--hairline);
  flex-wrap: wrap;
}

/* ── Toast ── */
.dd-toast {
  position: fixed; left: 50%; bottom: 32px;
  transform: translateX(-50%) translateY(40px);
  padding: 12px 22px;
  border-radius: 999px;
  background: var(--ink); color: var(--bone);
  font-family: var(--sans); font-size: 0.88rem; font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 18px 40px rgba(11,11,12,0.32);
  opacity: 0; pointer-events: none;
  z-index: 300;
  transition: opacity 240ms, transform 240ms cubic-bezier(.2,.7,.2,1);
}
.dd-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.dd-toast.success { background: linear-gradient(135deg, var(--forest), var(--forest-glow)); }
.dd-toast.warn    { background: linear-gradient(135deg, var(--champagne-deep), var(--champagne)); }

/* ── Form ── */
.dd-form { display: grid; gap: 14px; }
.dd-form label {
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
}
.dd-form input, .dd-form select, .dd-form textarea, .dd-textarea {
  width: 100%; min-height: 42px;
  padding: 10px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: 8px;
  background: white;
  color: var(--ink);
  font-family: var(--body); font-size: 0.96rem; font-weight: 400;
  letter-spacing: 0; text-transform: none;
  transition: border-color 180ms, box-shadow 180ms;
}
.dd-textarea { padding: 14px; min-height: 100px; resize: vertical; font-family: var(--display); line-height: 1.5; }
.dd-form input:focus, .dd-form select:focus, .dd-form textarea:focus, .dd-textarea:focus {
  outline: 0; border-color: var(--forest);
  box-shadow: 0 0 0 4px rgba(15,61,52,0.1);
}
.dd-form-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.dd-form-fieldset { border: 1px solid var(--hairline); border-radius: 10px; padding: 16px 18px; margin: 0; }
.dd-form-fieldset legend {
  padding: 0 8px;
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
}

/* ── Rubric sliders ── */
.dd-rubric { display: grid; gap: 10px; }
.dd-rubric-row {
  display: grid; grid-template-columns: 90px 1fr 56px 1.2fr; gap: 12px;
  align-items: center;
  padding: 8px 0; border-bottom: 1px dashed var(--hairline);
}
.dd-rubric-row:last-child { border-bottom: 0; }
.dd-rubric-row label {
  font-family: var(--sans); font-size: 0.78rem; font-weight: 800; text-transform: uppercase;
  color: var(--ink); letter-spacing: 0.04em;
}
.dd-rubric-row input[type=range] {
  width: 100%; accent-color: var(--forest);
}
.dd-rubric-row output {
  font-family: var(--mono); font-size: 0.84rem; font-weight: 700; color: var(--ink); text-align: center;
  padding: 4px 8px; background: var(--paper); border-radius: 999px;
}
.dd-rubric-row em { font-style: normal; color: var(--slate); font-size: 0.82rem; line-height: 1.4; }

/* ── Composite score ── */
.dd-composite {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 22px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--ink), var(--forest-deep));
  color: var(--bone);
  margin: 12px 0;
}
.dd-composite-num {
  font-family: var(--display); font-size: 3rem; font-weight: 300;
  letter-spacing: -0.02em; line-height: 1; color: var(--champagne);
}
.dd-composite-label {
  font-family: var(--sans); font-size: 0.72rem; font-weight: 800;
  letter-spacing: 0.16em; text-transform: uppercase; color: rgba(250,248,243,0.78);
}

/* ── Priors / lists ── */
.dd-priors { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.dd-priors li {
  padding: 8px 12px;
  background: rgba(255,255,255,0.6);
  border-left: 2px solid var(--champagne);
  border-radius: 4px;
  color: var(--ink); font-size: 0.9rem; line-height: 1.4;
}

/* ── Fit bars ── */
.dd-fit-bars { display: grid; gap: 10px; }
.dd-fit-row {
  display: grid; grid-template-columns: 130px 1fr 50px 100px; gap: 12px;
  align-items: center;
  padding: 8px 0; border-bottom: 1px dashed var(--hairline);
}
.dd-fit-row strong { font-family: var(--mono); font-size: 0.78rem; color: var(--slate); }
.dd-fit-bar {
  position: relative; height: 8px; background: var(--paper); border-radius: 999px; overflow: hidden;
}
.dd-fit-bar span {
  display: block; height: 100%; border-radius: 999px;
  background: linear-gradient(90deg, var(--forest), var(--champagne));
}
.dd-fit-row em { font-style: normal; font-family: var(--mono); font-size: 0.86rem; font-weight: 700; color: var(--ink); }

/* ── Ranked list ── */
.dd-ranked-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.dd-ranked-list li {
  display: grid; grid-template-columns: 70px 1fr auto auto auto; gap: 14px;
  align-items: center;
  padding: 14px 18px;
  border: 1px solid var(--hairline); border-radius: 10px;
  background: rgba(255,255,255,0.92);
  transition: background 180ms;
}
.dd-ranked-list li:hover { background: white; }
.dd-rank-fit {
  text-align: center;
  font-family: var(--display); font-size: 1.4rem; font-weight: 400;
  color: var(--forest); line-height: 1;
}
.dd-rank-fit em { font-style: normal; font-size: 0.66rem; color: var(--slate); display: block; }
.dd-rank-body strong { display: block; font-family: var(--display); font-size: 1.02rem; color: var(--ink); font-weight: 500; }
.dd-rank-body span { display: block; font-size: 0.82rem; color: var(--slate); margin-top: 2px; }

/* ── Activity feed ── */
.dd-activity-section {
  margin: 0 0 28px;
  padding: 22px 26px;
  border: 1px solid var(--hairline);
  border-radius: 18px;
  background: linear-gradient(135deg, var(--ink), var(--forest-deep));
  color: var(--bone);
  box-shadow: var(--shadow-card);
}
.dd-activity-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; flex-wrap: wrap; gap: 10px; }
.dd-activity-head .eyebrow { color: var(--champagne); margin: 0; }
.dd-activity-legend { font-family: var(--sans); font-size: 0.74rem; color: rgba(250,248,243,0.7); display: inline-flex; align-items: center; gap: 8px; }
.dd-activity-legend .dot.pulse {
  width: 7px; height: 7px; border-radius: 50%;
  background: #56e0a8;
  box-shadow: 0 0 0 0 rgba(86,224,168,0.6);
  animation: pulse 1.8s ease-out infinite;
  display: inline-block;
}
.dd-activity-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.dd-activity-item {
  display: grid; grid-template-columns: 80px 140px 1fr; gap: 14px;
  align-items: center;
  padding: 8px 12px;
  border-radius: 8px;
  background: rgba(255,255,255,0.06);
  transition: background 180ms;
}
.dd-activity-item:hover { background: rgba(255,255,255,0.12); }
.dd-act-time { font-family: var(--mono); font-size: 0.72rem; color: rgba(250,248,243,0.62); }
.dd-act-source { font-family: var(--sans); font-size: 0.74rem; font-weight: 800; letter-spacing: 0.06em; color: var(--champagne); text-transform: uppercase; }
.dd-act-text { font-family: var(--body); font-size: 0.86rem; color: rgba(250,248,243,0.92); line-height: 1.4; }

/* ── Shortlist floating bar ── */
.dd-shortlist-bar {
  position: fixed; bottom: 24px; right: 24px;
  z-index: 90;
  display: flex; gap: 12px; align-items: center;
  padding: 12px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--ink), var(--forest-deep));
  color: var(--bone);
  box-shadow: 0 24px 56px rgba(11,11,12,0.4);
  animation: ddSlideUp 240ms ease;
}
.dd-sl-count {
  font-family: var(--sans); font-size: 0.86rem; font-weight: 600;
  color: var(--bone);
}
.dd-sl-count b { color: var(--champagne); font-weight: 800; }
.dd-shortlist-bar .ghost-action {
  background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.18); color: var(--bone);
}
.dd-shortlist-bar .ghost-action:hover { background: rgba(255,255,255,0.18); }

/* ── App search/sort tools (injected) ── */
.dd-app-tools { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.dd-app-tools input, .dd-app-tools select {
  min-height: 38px; padding: 0 14px;
  border: 1px solid var(--hairline-strong); border-radius: 999px;
  background: white; color: var(--ink);
  font-family: var(--sans); font-size: 0.84rem;
}
.dd-app-tools input { min-width: 220px; }

/* ── Empty state ── */
.dd-empty {
  padding: 36px;
  border: 1px dashed var(--hairline-strong);
  border-radius: 12px;
  background: rgba(255,255,255,0.6);
  color: var(--slate);
  text-align: center;
  font-family: var(--display); font-style: italic; font-size: 1rem;
}

/* ── Applicant card shortlisted state ── */
.applicant-card.shortlisted {
  border-color: var(--forest); background: linear-gradient(150deg, rgba(15,61,52,0.04), rgba(255,255,255,0.96));
}
.applicant-card .is-on { color: var(--forest); font-weight: 800; }

/* ── Milestone list (portfolio detail) ── */
.dd-milestone-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.dd-milestone-list li {
  display: grid; grid-template-columns: 18px 1fr; gap: 12px;
  padding: 12px 14px;
  border-radius: 8px;
  background: rgba(250,248,243,0.6);
}
.dd-milestone-list li::before {
  content: ""; width: 14px; height: 14px; border-radius: 50%;
  background: var(--paper); border: 1px solid var(--hairline-strong);
  margin-top: 2px;
}
.dd-milestone-list li.done::before { background: var(--forest); border-color: var(--forest); }
.dd-milestone-list li.active::before {
  background: var(--bone); border-color: var(--forest);
  box-shadow: 0 0 0 3px rgba(15,61,52,0.18);
}
.dd-milestone-list li.pending::before { background: var(--paper); border-color: var(--hairline-strong); }
.dd-milestone-list li b { font-family: var(--display); font-size: 1.02rem; font-weight: 500; color: var(--ink); display: block; }
.dd-milestone-list li span { color: var(--slate); font-size: 0.84rem; line-height: 1.4; display: block; margin-top: 2px; }

@media (max-width: 720px) {
  .dd-modal { padding: 22px; }
  .dd-modal-title { font-size: 1.4rem; }
  .dd-form-row { grid-template-columns: 1fr; }
  .dd-rubric-row { grid-template-columns: 1fr; }
  .dd-fit-row { grid-template-columns: 1fr; }
  .dd-ranked-list li { grid-template-columns: 1fr; }
  .dd-activity-item { grid-template-columns: 1fr; }
  .dd-shortlist-bar { left: 16px; right: 16px; bottom: 16px; justify-content: center; }
}

/* ═════════════════════════════════════════════════════════════════════
   DONOR DESK (donors.html)
   ═════════════════════════════════════════════════════════════════════ */
.donor-body {
  background:
    radial-gradient(circle at 92% 4%, rgba(161, 132, 74, 0.13), transparent 32%),
    radial-gradient(circle at 6% 96%, rgba(15, 61, 52, 0.11), transparent 36%),
    linear-gradient(180deg, rgba(250, 248, 243, 0.98), rgba(242, 237, 229, 0.78)),
    var(--bone);
}
.donor-shell { width: min(1400px, calc(100% - 64px)); }
.donor-sidebar { grid-template-columns: minmax(220px, 0.5fr) minmax(0, 1.4fr) minmax(230px, 0.45fr); }
.donor-masthead h1 em {
  background: linear-gradient(95deg, var(--forest-deep), var(--champagne-deep) 90%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.donor-kpis { grid-template-columns: 1.2fr repeat(3, 1fr) 1.15fr; }
.donor-bento .bento-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.donor-bento .bento-lg { grid-column: span 3; }
.donor-bento .bento { grid-column: span 2; }

/* ── RFP cards ── */
.donor-rfps { margin: 36px 0; }
.rfp-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px;
}
.rfp-card {
  display: flex; flex-direction: column; gap: 12px;
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  transition: transform 200ms, box-shadow 200ms;
}
.rfp-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card); }
.rfp-card.open    { border-left: 4px solid var(--forest); }
.rfp-card.review  { border-left: 4px solid var(--champagne); }
.rfp-card header { display: flex; justify-content: space-between; align-items: center; }
.rfp-state {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
}
.rfp-state.open    { background: rgba(15,61,52,0.12); color: var(--forest); }
.rfp-state.review  { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.rfp-id {
  font-family: var(--mono); font-size: 0.72rem; color: var(--mauve);
}
.rfp-card h3 {
  font-family: var(--display); font-size: 1.18rem; font-weight: 500;
  letter-spacing: -0.005em; line-height: 1.2; color: var(--ink); text-transform: none;
}
.rfp-meta { margin: 0; color: var(--slate); font-size: 0.86rem; line-height: 1.45; }
.rfp-meta b { color: var(--ink); font-weight: 700; }

.rfp-pipeline {
  display: grid; gap: 6px;
  padding: 10px 0; border-top: 1px dashed var(--hairline); border-bottom: 1px dashed var(--hairline);
}
.rfp-stage {
  position: relative; display: flex; align-items: center; gap: 10px;
  padding: 4px 0;
  font-family: var(--sans); font-size: 0.78rem; color: var(--slate);
}
.rfp-stage::before {
  content: ""; display: block; width: var(--w);
  height: 6px; border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--forest), var(--champagne));
  position: absolute; left: 0; bottom: -2px;
  opacity: 0.7;
}
.rfp-stage span {
  font-family: var(--display); font-size: 1.05rem; font-weight: 500; color: var(--ink);
  min-width: 28px;
}
.rfp-stage em {
  font-style: normal; color: var(--slate); font-size: 0.78rem;
}
.rfp-card footer { margin-top: auto; padding-top: 4px; }

/* ── Applicant pool ── */
.donor-applicants { margin: 36px 0; }
.applicant-filters {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.applicant-filters select {
  min-height: 38px; padding: 0 14px;
  border: 1px solid var(--hairline-strong); border-radius: var(--r-pill);
  background: white; color: var(--ink);
  font-family: var(--sans); font-size: 0.82rem; font-weight: 600;
}
.applicant-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px;
}
.applicant-card {
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.applicant-card:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-card);
  border-color: rgba(15,61,52,0.32);
}
.applicant-card header { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.app-tag {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 4px 9px; border-radius: var(--r-pill);
  background: var(--paper); color: var(--slate);
}
.fit-score {
  font-family: var(--display); font-size: 1.6rem; font-weight: 400;
  letter-spacing: -0.01em; color: var(--forest); line-height: 1;
}
.fit-score em { font-style: normal; font-size: 0.7rem; color: var(--slate); font-family: var(--sans); margin-left: 2px; }
.applicant-card h3 {
  font-family: var(--display); font-size: 1.2rem; font-weight: 500;
  letter-spacing: -0.005em; line-height: 1.2; color: var(--ink); text-transform: none;
}
.app-loc { margin: 0; font-family: var(--sans); font-size: 0.8rem; color: var(--slate); }
.app-sectors { display: flex; flex-wrap: wrap; gap: 6px; }
.app-sectors span {
  padding: 3px 9px; border-radius: var(--r-pill);
  background: rgba(15,61,52,0.08); color: var(--forest);
  font-family: var(--sans); font-size: 0.7rem; font-weight: 700;
}
.app-stats {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px;
  margin: 4px 0 0; padding-top: 10px; border-top: 1px dashed var(--hairline);
}
.app-stats dt { font-size: 0.62rem; color: var(--champagne-deep); font-family: var(--sans); font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; }
.app-stats dd { margin: 2px 0 0; font-family: var(--mono); font-size: 0.9rem; color: var(--ink); font-weight: 700; }
.applicant-card footer { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 8px; }

/* ── Review workspace ── */
.donor-review { margin: 36px 0; }
.review-card {
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.96);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.review-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 26px 30px;
  background: linear-gradient(135deg, rgba(15,61,52,0.06), rgba(161,132,74,0.04));
  border-bottom: 1px solid var(--hairline);
}
.review-head .rfp-id { display: block; margin-bottom: 6px; }
.review-head h3 {
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.008em; color: var(--ink); margin: 0 0 4px; text-transform: none;
}
.review-sub { margin: 0; color: var(--slate); font-size: 0.86rem; }
.review-score { text-align: center; padding-left: 24px; border-left: 1px solid var(--hairline-strong); }
.score-num {
  font-family: var(--display); font-size: 3.2rem; font-weight: 300;
  color: var(--forest-deep); line-height: 1; letter-spacing: -0.02em;
}
.score-label {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.12em; color: var(--champagne-deep);
}

.review-body {
  display: grid; grid-template-columns: 1.2fr 1fr;
  gap: 1px;
  background: var(--hairline);
}
.review-col { padding: 26px 30px; background: white; }
.review-col h4 {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  margin: 0 0 14px;
}
.review-col h4.mt { margin-top: 22px; }
.review-rubric { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.review-rubric li {
  display: grid; grid-template-columns: 70px 50px 1fr; gap: 10px;
  align-items: center;
  padding: 8px 0; border-bottom: 1px dashed var(--hairline);
}
.review-rubric li:last-child { border-bottom: 0; }
.rub-l { font-family: var(--sans); font-size: 0.78rem; font-weight: 800; color: var(--ink); text-transform: uppercase; letter-spacing: 0.04em; }
.review-rubric b {
  font-family: var(--mono); font-size: 0.9rem; font-weight: 700;
  padding: 3px 8px; border-radius: var(--r-pill); text-align: center;
}
.review-rubric b.ok   { background: rgba(15,61,52,0.12); color: var(--forest); }
.review-rubric b.warn { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.review-rubric em { font-style: normal; color: var(--slate); font-size: 0.84rem; line-height: 1.42; }

.review-prior { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.review-prior li {
  padding: 8px 0; border-bottom: 1px dashed var(--hairline);
  font-family: var(--display); font-size: 0.9rem; color: var(--ink); line-height: 1.4;
}
.review-prior li:last-child { border-bottom: 0; }
.review-prior b { font-weight: 600; }
.review-col p { color: var(--slate); font-size: 0.92rem; line-height: 1.55; font-family: var(--display); font-style: italic; }

.review-foot {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 18px 30px; border-top: 1px solid var(--hairline);
  background: rgba(250,248,243,0.6);
}

/* ── Portfolio ── */
.donor-portfolio { margin: 36px 0; }
.portfolio-table-wrap {
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: white;
  overflow-x: auto;
  box-shadow: var(--shadow-card);
}
.portfolio-table { width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: 0.88rem; }
.portfolio-table thead { background: var(--ink); }
.portfolio-table th {
  padding: 14px 18px; text-align: left;
  color: var(--champagne);
  font-size: 0.7rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase;
  white-space: nowrap;
}
.portfolio-table td {
  padding: 16px 18px; border-bottom: 1px solid var(--hairline);
  color: var(--ink); vertical-align: top;
}
.portfolio-table tbody tr:hover { background: rgba(15,61,52,0.03); }
.portfolio-table tbody tr:last-child td { border-bottom: 0; }
.portfolio-table td b { font-family: var(--display); font-size: 1rem; font-weight: 500; }
.portfolio-table td small { display: block; color: var(--slate); font-size: 0.76rem; margin-top: 2px; }

.ms { display: flex; gap: 4px; align-items: center; }
.ms span {
  width: 12px; height: 12px; border-radius: 50%; background: var(--paper); border: 1px solid var(--hairline-strong); display: inline-block;
}
.ms .ms-on    { background: var(--forest); border-color: var(--forest); }
.ms .ms-amber { background: var(--champagne); border-color: var(--champagne-deep); }
.ms .ms-now   {
  background: var(--bone); border-color: var(--forest);
  box-shadow: 0 0 0 2px rgba(15,61,52,0.18);
}
.health { font-family: var(--sans); font-size: 0.74rem; font-weight: 700; padding: 3px 9px; border-radius: var(--r-pill); display: inline-block; }
.health.green { background: rgba(15,61,52,0.12); color: var(--forest); }
.health.amber { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.health.red   { background: rgba(140,42,42,0.12); color: #8c2a2a; }

.portfolio-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 4px; flex-wrap: wrap; gap: 12px;
  font-family: var(--sans); font-size: 0.86rem; color: var(--slate);
}
.portfolio-foot b { color: var(--ink); font-weight: 800; }

/* ── Co-funder section ── */
.cofunder-section { margin: 36px 0; }
.cofunder-card {
  padding: 32px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow-card);
}
.cofunder-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--hairline);
}
.cf-cluster {
  padding: 20px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(250,248,243,0.6);
}
.cf-cluster h4 {
  font-family: var(--display); font-size: 1.05rem; font-weight: 500;
  letter-spacing: -0.005em; text-transform: none; color: var(--ink); margin: 0 0 10px;
}
.cf-cluster ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 7px; }
.cf-cluster li {
  display: flex; align-items: center; gap: 9px;
  font-size: 0.86rem; color: var(--slate); line-height: 1.42;
}
.cf-cluster li.self { color: var(--ink); font-weight: 700; padding-bottom: 7px; border-bottom: 1px dashed var(--hairline); margin-bottom: 4px; }
.cf-cluster li em { font-style: italic; color: var(--champagne-deep); }
.cf-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--mauve); display: inline-block; flex-shrink: 0; }
.cf-dot.self { background: var(--champagne); box-shadow: 0 0 0 3px rgba(161,132,74,0.18); }
.cofunder-insights {
  padding-top: 24px;
}
.cofunder-insights p {
  font-family: var(--display); font-size: 1rem; line-height: 1.6;
  color: var(--ink); margin: 0 0 10px;
}
.cofunder-insights b { font-weight: 600; }

/* ── Donor intelligence (self) ── */
.donor-intel-section { margin: 36px 0; }
.donor-self-card {
  padding: 32px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background: linear-gradient(160deg, rgba(255,255,255,0.96) 60%, rgba(161,132,74,0.06));
  box-shadow: var(--shadow-card);
}
.donor-self-grid { display: grid; grid-template-columns: 1.5fr 1fr; gap: 32px; }
.donor-self-grid h3 {
  font-family: var(--display); font-size: 1.8rem; font-weight: 500;
  letter-spacing: -0.012em; color: var(--ink); margin: 0 0 6px; text-transform: none;
}
.donor-self-tag {
  display: inline-block; padding: 3px 10px;
  border-radius: var(--r-pill); background: var(--ink); color: var(--champagne);
  font-family: var(--sans); font-size: 0.72rem; font-weight: 800; letter-spacing: 0.06em; margin-bottom: 14px;
}
.donor-self-blurb {
  font-family: var(--display); font-style: italic; font-size: 1.04rem; line-height: 1.55;
  color: var(--slate); margin: 0 0 18px;
}
.donor-self-dl { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 22px; margin: 0; }
.donor-self-dl dt { color: var(--champagne-deep); font-family: var(--sans); font-size: 0.7rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; }
.donor-self-dl dd { margin: 4px 0 0; color: var(--ink); font-size: 0.92rem; font-family: var(--display); font-weight: 500; }

.donor-self-signal {
  padding: 22px;
  border-radius: var(--r-lg);
  background: linear-gradient(150deg, var(--ink), var(--forest-deep));
  color: var(--bone);
}
.donor-self-signal h4 {
  color: var(--champagne);
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase;
  margin: 0 0 14px;
}
.donor-self-stats { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.donor-self-stats li { display: flex; align-items: baseline; gap: 12px; }
.donor-self-stats b { font-family: var(--display); font-size: 1.4rem; font-weight: 300; color: var(--bone); letter-spacing: -0.01em; min-width: 64px; }
.donor-self-stats span { color: rgba(250,248,243,0.74); font-family: var(--sans); font-size: 0.78rem; }
.signal-note {
  margin: 16px 0 0; padding-top: 14px; border-top: 1px solid rgba(255,255,255,0.18);
  font-family: var(--display); font-style: italic; font-size: 0.92rem; color: var(--champagne);
}

/* ── Wedge / why-IWHF ── */
.donor-wedge { margin: 36px 0; }
.wedge-grid {
  display: grid; grid-template-columns: 1fr 1.2fr 1fr; gap: 14px;
}
.wedge-col {
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  display: flex; flex-direction: column; gap: 12px;
}
.wedge-col header { display: flex; }
.wedge-tag {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 12px; border-radius: var(--r-pill);
  background: var(--paper); color: var(--slate);
}
.wedge-col.primary {
  background: linear-gradient(165deg, var(--ink), var(--forest-deep));
  color: var(--bone); border-color: transparent;
  transform: translateY(-6px);
  box-shadow: 0 28px 64px rgba(15,61,52,0.18);
}
.wedge-col.primary .wedge-tag { background: var(--champagne); color: var(--ink); }
.wedge-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.wedge-col li { display: grid; grid-template-columns: 1fr; gap: 2px; padding: 10px 0; border-bottom: 1px dashed var(--hairline); }
.wedge-col.primary li { border-bottom-color: rgba(255,255,255,0.18); }
.wedge-col li b { font-family: var(--display); font-size: 1.04rem; font-weight: 500; color: var(--ink); letter-spacing: -0.005em; }
.wedge-col.primary li b { color: var(--bone); }
.wedge-col li span { font-family: var(--sans); font-size: 0.82rem; color: var(--slate); }
.wedge-col.primary li span { color: rgba(250,248,243,0.78); }
.wedge-col li.total { border-bottom: 0; padding-top: 14px; border-top: 1px solid var(--hairline); }
.wedge-col.primary li.total { border-top-color: rgba(255,255,255,0.32); }
.wedge-col li.total b { font-size: 1.2rem; }
.wedge-col li.total.ok b { color: var(--forest); }

.wedge-cta {
  display: flex; justify-content: space-between; align-items: center;
  gap: 22px; flex-wrap: wrap;
  margin-top: 22px; padding: 26px;
  border: 1px solid var(--champagne);
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, rgba(161,132,74,0.10), rgba(255,255,255,0.92));
}
.wedge-cta strong { font-family: var(--display); font-size: 1.5rem; font-weight: 500; color: var(--ink); letter-spacing: -0.012em; display: block; margin-bottom: 6px; }
.wedge-cta p { margin: 0; color: var(--slate); font-size: 0.94rem; line-height: 1.5; max-width: 580px; }

/* ── Two-sided integration ── */
.two-sided { margin: 36px 0; }
.two-sided-grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px;
  align-items: stretch;
}
.two-sided-col {
  padding: 28px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  display: flex; flex-direction: column; gap: 12px;
}
.two-sided-col.subscriber { border-top: 4px solid var(--forest); }
.two-sided-col.donor { border-top: 4px solid var(--champagne); }
.two-sided-col header h3 {
  font-family: var(--display); font-size: 1.32rem; font-weight: 500;
  letter-spacing: -0.008em; color: var(--ink); text-transform: none; margin: 4px 0 0;
}
.ts-tag {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
  background: var(--paper); color: var(--slate); display: inline-block;
}
.two-sided-col.subscriber .ts-tag { background: rgba(15,61,52,0.12); color: var(--forest); }
.two-sided-col.donor .ts-tag { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.two-sided-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.two-sided-col li { color: var(--slate); font-size: 0.9rem; line-height: 1.5; }
.two-sided-col li::before { content: "→ "; color: var(--champagne); font-weight: 800; }
.two-sided-col > a { margin-top: auto; align-self: flex-start; }

.two-sided-bridge {
  padding: 28px 22px;
  border: 1px dashed var(--champagne);
  border-radius: var(--r-lg);
  background: linear-gradient(160deg, var(--ink), var(--forest-deep));
  color: var(--bone);
  display: flex; flex-direction: column; gap: 14px;
  align-items: center; justify-content: center; text-align: center;
}
.bridge-rule {
  width: 80%; height: 1px; background: linear-gradient(90deg, transparent, var(--champagne), transparent);
}
.bridge-label {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--champagne);
}
.bridge-stack { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.bridge-stack li { font-family: var(--display); font-style: italic; font-size: 0.96rem; color: rgba(250,248,243,0.92); }

@media (max-width: 1180px) {
  .donor-shell { width: min(100% - 36px, 1400px); }
  .donor-kpis { grid-template-columns: repeat(3, 1fr); }
  .donor-bento .bento-grid { grid-template-columns: repeat(4, 1fr); }
  .donor-bento .bento, .donor-bento .bento-lg { grid-column: span 2; }
  .rfp-grid { grid-template-columns: 1fr; }
  .applicant-grid { grid-template-columns: repeat(2, 1fr); }
  .review-body { grid-template-columns: 1fr; }
  .donor-self-grid { grid-template-columns: 1fr; }
  .wedge-grid { grid-template-columns: 1fr; }
  .wedge-col.primary { transform: none; }
  .two-sided-grid { grid-template-columns: 1fr; }
  .cofunder-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .donor-bento .bento-grid { grid-template-columns: 1fr 1fr; }
  .applicant-grid { grid-template-columns: 1fr; }
  .review-head { flex-direction: column; align-items: flex-start; }
  .review-score { padding-left: 0; padding-top: 14px; border-left: 0; border-top: 1px solid var(--hairline-strong); width: 100%; text-align: left; }
}

/* ═════════════════════════════════════════════════════════════════════
   FOUNDER PORTAL · functional grant-writing chrome (dashboard.html)
   ═════════════════════════════════════════════════════════════════════ */

/* ── Brand selector inside drafter modal ── */
.fp-brand-selector label {
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
  text-align: right;
}
.fp-brand-selector select {
  min-height: 38px; padding: 0 14px;
  border: 1px solid var(--hairline-strong); border-radius: 999px;
  background: white; color: var(--ink);
  font-family: var(--display); font-size: 0.96rem; font-weight: 500;
  letter-spacing: 0; text-transform: none;
}

/* ── Doc preview ── */
.fp-doc {
  padding: 26px 30px;
  border: 1px solid var(--hairline);
  border-radius: 14px;
  background: rgba(250, 248, 243, 0.6);
  max-height: 480px;
  overflow-y: auto;
}
.fp-doc-section { margin-bottom: 18px; }
.fp-doc-section:last-child { margin-bottom: 0; }
.fp-doc-section h3 {
  font-family: var(--sans); font-size: 0.74rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--champagne-deep); margin: 0 0 6px;
}
.fp-doc-section p {
  font-family: var(--display); font-size: 1rem; line-height: 1.62;
  color: var(--ink); margin: 0;
}

.fp-doc-meta {
  margin-top: 12px;
}
.fp-doc-trace {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  border: 1px dashed var(--hairline-strong);
  border-radius: 10px;
  background: rgba(255,255,255,0.6);
  color: var(--slate);
  font-family: var(--sans); font-size: 0.82rem;
}
.fp-doc-trace .trace-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #56e0a8;
  box-shadow: 0 0 0 3px rgba(86,224,168,0.16);
  flex-shrink: 0;
}
.fp-doc-trace b { color: var(--ink); font-weight: 700; }

/* ── Full editor ── */
.fp-editor { display: grid; gap: 18px; max-height: 540px; overflow-y: auto; padding-right: 6px; }
.fp-edit-section {
  border: 1px solid var(--hairline);
  border-radius: 10px;
  background: white;
  overflow: hidden;
}
.fp-edit-section header {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--paper);
  border-bottom: 1px solid var(--hairline);
}
.fp-section-num {
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
  color: var(--champagne-deep); padding: 3px 8px; border-radius: 6px;
  background: rgba(161,132,74,0.16);
}
.fp-edit-section header h3 {
  flex: 1; margin: 0;
  font-family: var(--sans); font-size: 0.78rem; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink);
}
.fp-edit-body {
  padding: 18px 22px;
  font-family: var(--display); font-size: 1.02rem; line-height: 1.65;
  color: var(--ink);
  outline: 0;
  transition: background 180ms;
}
.fp-edit-body:focus { background: rgba(15,61,52,0.03); }

/* ── Budget Architect ── */
.fp-budget-header label {
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
  text-align: right;
}
.fp-budget-header input {
  min-height: 38px; padding: 0 14px;
  border: 1px solid var(--hairline-strong); border-radius: 10px;
  background: white; color: var(--ink);
  font-family: var(--mono); font-size: 1rem; font-weight: 700;
  width: 180px; text-align: right;
}

.fp-budget-table {
  border: 1px solid var(--hairline);
  border-radius: 12px;
  overflow: hidden;
  margin: 18px 0;
}
.fp-budget-tbl { width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: 0.88rem; }
.fp-budget-tbl thead { background: var(--ink); }
.fp-budget-tbl thead th {
  padding: 12px 14px; text-align: left;
  color: var(--champagne); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase;
}
.fp-budget-tbl tbody td {
  padding: 10px 14px; border-bottom: 1px solid var(--hairline);
  color: var(--ink); vertical-align: middle;
}
.fp-budget-tbl tbody tr:last-child td { border-bottom: 0; }
.fp-budget-tbl tbody tr:hover { background: rgba(15,61,52,0.03); }
.fp-budget-tbl td b { font-family: var(--display); font-weight: 500; color: var(--ink); }
.fp-budget-tbl input {
  width: 100%; min-height: 32px; padding: 6px 8px;
  border: 1px solid var(--hairline-strong); border-radius: 6px;
  background: white; color: var(--ink);
  font-family: var(--mono); font-size: 0.86rem; text-align: right;
}
.fp-line-total { font-family: var(--mono); font-weight: 700; color: var(--forest); white-space: nowrap; }
.fp-budget-tbl .text-action { color: var(--mauve); padding: 4px 8px; }
.fp-budget-tbl .text-action:hover { color: #8c2a2a; }

.fp-budget-summary {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px;
  margin-bottom: 16px;
}
.fp-budget-cat {
  padding: 14px 16px;
  border: 1px solid var(--hairline); border-radius: 10px;
  background: rgba(255,255,255,0.92);
}
.fp-budget-cat span {
  display: block;
  font-family: var(--sans); font-size: 0.64rem; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--champagne-deep);
}
.fp-budget-cat b {
  display: block; margin-top: 4px;
  font-family: var(--display); font-size: 1.2rem; font-weight: 500;
  color: var(--ink); letter-spacing: -0.005em;
}
.fp-budget-cat.total {
  background: linear-gradient(135deg, var(--ink), var(--forest-deep));
  border-color: transparent; color: var(--bone);
}
.fp-budget-cat.total span { color: var(--champagne); }
.fp-budget-cat.total b { color: var(--bone); }

.fp-budget-note {
  padding: 14px 18px;
  border-radius: 10px;
  background: rgba(161,132,74,0.08);
  border-left: 3px solid var(--champagne);
  color: var(--slate);
  font-family: var(--body); font-size: 0.88rem; line-height: 1.5;
}
.fp-budget-note p { margin: 0; }

/* ── Format card on the Drafter preview ── */
.fp-format-card {
  display: flex; justify-content: space-between; align-items: center;
  gap: 18px; flex-wrap: wrap;
  padding: 14px 18px;
  margin-bottom: 16px;
  border: 1px solid var(--hairline);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(15,61,52,0.04), rgba(161,132,74,0.04));
}
.fp-format-meta { display: flex; gap: 12px; align-items: center; color: var(--slate); font-family: var(--sans); font-size: 0.84rem; }
.fp-format-pill {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 999px;
  background: var(--ink); color: var(--champagne);
}
.fp-format-submission { font-family: var(--sans); font-size: 0.84rem; color: var(--slate); }
.fp-format-submission b { color: var(--ink); font-weight: 700; }
.fp-doc-target {
  font-family: var(--mono); font-size: 0.72rem; font-weight: 500;
  color: var(--slate); text-transform: none; letter-spacing: 0;
  margin-left: 8px;
}
.fp-doc-hint { color: var(--mauve); font-size: 0.84rem; margin: 0 0 6px; }

/* ═════════════════════════════════════════════════════════════════════
   FULL COMPOSER · Studio editor (dashboard.html)
   ═════════════════════════════════════════════════════════════════════ */

/* Make the composer modal effectively full-screen */
.dd-modal.full {
  max-width: 1280px;
  width: calc(100vw - 48px);
  max-height: 92vh;
  height: 92vh;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.dd-modal.full .dd-modal-close { z-index: 3; }

.fp-composer { display: flex; flex-direction: column; height: 100%; min-height: 0; }

.fp-composer-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 18px 28px;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, var(--bone), rgba(250,248,243,0.96));
  flex-wrap: wrap; gap: 12px;
}
.fp-composer-titles .rfp-id { display: block; font-family: var(--mono); font-size: 0.74rem; color: var(--slate); }
.fp-composer-titles .rfp-id b { color: var(--ink); font-weight: 800; }
.fp-composer-titles h2 {
  margin: 4px 0 2px;
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.012em; color: var(--ink);
}
.fp-composer-titles p { margin: 0; color: var(--slate); font-size: 0.86rem; }
.fp-composer-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.fp-autosave {
  font-family: var(--mono); font-size: 0.74rem; color: var(--slate);
  padding: 5px 10px; border-radius: 999px;
  background: rgba(15,61,52,0.08); border: 1px solid var(--hairline);
}

.fp-composer-body {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 0;
  flex: 1; min-height: 0;
  overflow: hidden;
}

/* LEFT · section nav */
.fp-composer-nav {
  border-right: 1px solid var(--hairline);
  background: var(--paper);
  overflow-y: auto;
  padding: 18px 14px;
  display: flex; flex-direction: column; gap: 14px;
}
.fp-composer-nav h4, .fp-composer-nav h5 {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  margin: 0 0 6px;
}
.fp-composer-nav h5.mt { margin-top: 14px; }
.fp-section-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.fp-section-list li {
  display: grid; grid-template-columns: 26px 1fr 18px; gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 8px; cursor: pointer;
  transition: background 180ms;
}
.fp-section-list li:hover { background: rgba(255,255,255,0.7); }
.fp-section-list li.active { background: white; box-shadow: 0 4px 14px rgba(11,11,12,0.06); }
.fp-nav-num {
  font-family: var(--mono); font-size: 0.7rem; font-weight: 700;
  color: var(--champagne-deep); text-align: center;
  padding: 3px 0; border-radius: 4px;
  background: rgba(161,132,74,0.12);
}
.fp-nav-body { min-width: 0; }
.fp-nav-body strong {
  display: block;
  font-family: var(--sans); font-size: 0.84rem; font-weight: 700;
  color: var(--ink); line-height: 1.22;
}
.fp-nav-body strong em { font-style: italic; color: var(--mauve); font-weight: 400; font-size: 0.74rem; }
.fp-nav-target {
  display: block;
  font-family: var(--mono); font-size: 0.7rem; color: var(--slate);
}
.fp-nav-status {
  font-size: 1rem; text-align: center; line-height: 1;
  font-weight: 700;
}
.fp-nav-status.ok    { color: var(--forest); }
.fp-nav-status.under { color: var(--mauve); }
.fp-nav-status.over  { color: #8c2a2a; }

.fp-submission-card {
  padding: 14px;
  border-radius: 10px;
  background: rgba(255,255,255,0.7);
  border: 1px solid var(--hairline);
}
.fp-submission-card p { margin: 0 0 6px; font-size: 0.82rem; color: var(--slate); line-height: 1.4; }
.fp-submission-card p b { color: var(--ink); font-weight: 700; }
.fp-submission-card ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.fp-submission-card ul li {
  font-size: 0.8rem; color: var(--slate);
  padding-left: 14px; position: relative; line-height: 1.4;
}
.fp-submission-card ul li::before {
  content: "•"; position: absolute; left: 0; color: var(--champagne);
}

/* CENTER · main editor */
.fp-composer-main {
  display: flex; flex-direction: column;
  min-width: 0; min-height: 0;
  background: white;
}
.fp-section-meta {
  padding: 20px 30px 12px;
  border-bottom: 1px solid var(--hairline);
}
.fp-section-meta .kicker {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  display: block; margin-bottom: 4px;
}
.fp-section-meta h3 {
  margin: 0 0 4px;
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.008em; color: var(--ink); text-transform: none;
}
.fp-section-meta .muted { margin: 0; color: var(--slate); font-size: 0.86rem; line-height: 1.42; }

.fp-edit-toolbar {
  display: flex; gap: 6px; flex-wrap: wrap;
  padding: 10px 30px;
  background: rgba(250, 248, 243, 0.5);
  border-bottom: 1px solid var(--hairline);
}

#fp-edit-body.fp-edit-body {
  flex: 1; min-height: 0;
  padding: 24px 30px;
  overflow-y: auto;
  font-family: var(--display); font-size: 1.06rem; line-height: 1.7;
  color: var(--ink);
  outline: 0;
  white-space: pre-wrap;
}
#fp-edit-body.fp-edit-body:focus { background: rgba(15,61,52,0.02); }

.fp-section-foot {
  display: flex; justify-content: space-between; align-items: center;
  gap: 14px;
  padding: 14px 30px;
  border-top: 1px solid var(--hairline);
  background: var(--paper);
}
.fp-wordcount { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 0; }
.fp-wc-num {
  font-family: var(--display); font-size: 1.4rem; font-weight: 400;
  color: var(--ink); letter-spacing: -0.01em; min-width: 50px;
}
.fp-wc-target {
  font-family: var(--sans); font-size: 0.78rem; color: var(--slate);
}
.fp-wc-bar {
  flex: 1; height: 5px; max-width: 240px;
  border-radius: 999px; background: var(--hairline-strong);
  overflow: hidden;
}
.fp-wc-bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--forest), var(--champagne));
  border-radius: 999px;
}
.fp-wordcount.under .fp-wc-num { color: var(--mauve); }
.fp-wordcount.over .fp-wc-num { color: #8c2a2a; }
.fp-wordcount.ok .fp-wc-num { color: var(--forest); }
.fp-section-pager { display: flex; gap: 8px; }
.fp-section-pager button[disabled] { opacity: 0.4; pointer-events: none; }

/* RIGHT · readiness + rubric */
.fp-composer-side {
  border-left: 1px solid var(--hairline);
  background: rgba(250, 248, 243, 0.6);
  overflow-y: auto;
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 18px;
}
.fp-readiness h5, .fp-rubric-panel h5 {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  margin: 0 0 8px;
}
.fp-ready-bar {
  height: 6px; border-radius: 999px; background: var(--hairline-strong); overflow: hidden;
  margin-bottom: 8px;
}
.fp-ready-bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--champagne), var(--forest));
  border-radius: 999px;
}
.fp-ready-bar.ok > span { background: linear-gradient(90deg, var(--forest), var(--forest-glow)); }
.fp-ready-num {
  font-family: var(--mono); font-size: 0.82rem; color: var(--ink); margin-bottom: 10px;
}
.fp-ready-list { list-style: none; padding: 0; margin: 0 0 12px; display: grid; gap: 5px; }
.fp-ready-list li {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 8px; border-radius: 6px;
  font-size: 0.82rem; color: var(--slate);
  background: rgba(255,255,255,0.6);
}
.fp-ready-list li.ok { color: var(--ink); }
.fp-ready-mark {
  display: inline-grid; place-items: center;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--paper); color: var(--mauve);
  font-size: 0.7rem; font-weight: 800;
}
.fp-ready-list li.ok .fp-ready-mark { background: var(--forest); color: var(--bone); }

.fp-ready-warn {
  padding: 8px 10px; margin: 10px 0;
  border-radius: 6px;
  background: rgba(140,42,42,0.1); color: #8c2a2a;
  font-size: 0.78rem; line-height: 1.4;
}
.primary-action.disabled { opacity: 0.4; pointer-events: none; }

.fp-rubric-panel ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 4px; }
.fp-rubric-panel li {
  display: flex; justify-content: space-between; align-items: center;
  padding: 5px 8px; border-radius: 6px;
  background: rgba(255,255,255,0.6);
  font-family: var(--sans); font-size: 0.82rem;
}
.fp-rubric-panel li b { font-family: var(--mono); color: var(--forest); }

@media (max-width: 1100px) {
  .fp-composer-body { grid-template-columns: 220px 1fr 220px; }
}
@media (max-width: 900px) {
  .fp-composer-body { grid-template-columns: 1fr; }
  .fp-composer-nav, .fp-composer-side { border: 0; }
}

/* ── Org Profile Composer · personalization foundation ── */

/* Hero card on the dashboard */
.pc-hero-card {
  display: flex; justify-content: space-between; align-items: center;
  gap: 28px; flex-wrap: wrap;
  margin: 0 0 28px;
  padding: 24px 28px;
  border: 1px solid var(--hairline);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(15,61,52,0.06), rgba(161,132,74,0.06), rgba(255,255,255,0.92));
  cursor: pointer;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.pc-hero-card:hover { transform: translateY(-2px); border-color: rgba(15,61,52,0.32); box-shadow: var(--shadow-card); }
.pc-hero-left { flex: 1; min-width: 280px; }
.pc-hero-left .kicker {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--champagne-deep);
  display: block; margin-bottom: 8px;
}
.pc-hero-left h3 {
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.012em; color: var(--ink); margin: 0 0 8px;
  text-transform: none;
}
.pc-hero-left p { margin: 0 0 4px; color: var(--slate); font-size: 0.96rem; line-height: 1.5; }
.pc-hero-left .pc-next-section { color: var(--slate); font-size: 0.86rem; }
.pc-hero-left .pc-next-section b { color: var(--ink); }
.pc-hero-ring { display: flex; align-items: center; gap: 18px; flex-direction: column; }

/* Score ring */
.pc-score-ring {
  --p: 0;
  width: 88px; height: 88px;
  border-radius: 50%;
  background: conic-gradient(var(--forest) calc(var(--p) * 1%), rgba(11,11,12,0.08) 0);
  display: grid; place-items: center;
  position: relative;
}
.pc-score-ring::before {
  content: ""; position: absolute; inset: 6px;
  background: var(--bone); border-radius: 50%;
}
.pc-score-ring span {
  position: relative;
  font-family: var(--display); font-size: 1.5rem; font-weight: 400;
  color: var(--ink); line-height: 1; letter-spacing: -0.01em;
}
.pc-score-ring span em { font-style: normal; font-size: 0.7rem; color: var(--slate); margin-left: 2px; }
.pc-score-ring.lg { width: 128px; height: 128px; }
.pc-score-ring.lg span { font-size: 2.2rem; }
.pc-score-ring.lg::before { inset: 10px; }

/* Modal */
.pc-modal { padding: 0 !important; display: flex; flex-direction: column; height: 88vh; max-height: 88vh; }
.pc-composer { display: flex; flex-direction: column; height: 100%; min-height: 0; }
.pc-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 28px;
  border-bottom: 1px solid var(--hairline);
  background: linear-gradient(180deg, var(--bone), rgba(250,248,243,0.96));
  gap: 16px; flex-wrap: wrap;
}
.pc-head-titles .rfp-id {
  font-family: var(--mono); font-size: 0.74rem; color: var(--slate);
}
.pc-head-titles h2 {
  margin: 4px 0 2px;
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.012em; color: var(--ink);
}
.pc-head-titles p { margin: 0; color: var(--slate); font-size: 0.86rem; }
.pc-head-titles p b { color: var(--ink); font-weight: 700; }
.pc-head-meta {
  display: flex; gap: 16px; align-items: center;
}
.pc-score-meta { text-align: right; }
.pc-score-meta .kicker {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
  display: block;
}
.pc-score-meta strong {
  font-family: var(--display); font-size: 1.3rem; font-weight: 500;
  color: var(--ink); line-height: 1.1;
}

.pc-body {
  display: grid; grid-template-columns: 260px 1fr;
  flex: 1; min-height: 0;
}
.pc-nav {
  border-right: 1px solid var(--hairline);
  background: var(--paper);
  overflow-y: auto;
  padding: 14px 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.pc-nav-item {
  display: grid; grid-template-columns: 28px 1fr; gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border: 0; background: transparent;
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  transition: background 180ms;
}
.pc-nav-item:hover { background: rgba(255,255,255,0.7); }
.pc-nav-item.active { background: white; box-shadow: 0 4px 14px rgba(11,11,12,0.06); }
.pc-nav-icon {
  display: grid; place-items: center;
  font-size: 0.9rem; color: var(--champagne);
  width: 28px; height: 28px;
  background: rgba(161,132,74,0.12); border-radius: 50%;
}
.pc-nav-item > div { min-width: 0; }
.pc-nav-item strong {
  display: block;
  font-family: var(--sans); font-size: 0.84rem; font-weight: 700;
  color: var(--ink);
}
.pc-nav-status {
  display: block;
  font-family: var(--mono); font-size: 0.7rem; color: var(--mauve); margin-top: 2px;
}
.pc-nav-status.ok      { color: var(--forest); }
.pc-nav-status.partial { color: var(--champagne-deep); }
.pc-nav-status.todo    { color: var(--mauve); }
.pc-nav-status.soft    { color: var(--mauve); font-style: italic; }

.pc-pane {
  overflow-y: auto;
  padding: 28px 30px;
  background: white;
}
.pc-section-head { margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--hairline); }
.pc-section-head .kicker {
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
  letter-spacing: 0.14em; color: var(--champagne-deep);
  display: block; margin-bottom: 4px;
}
.pc-section-head h3 {
  margin: 0 0 6px;
  font-family: var(--display); font-size: 1.5rem; font-weight: 500;
  letter-spacing: -0.008em; color: var(--ink); text-transform: none;
}
.pc-unlocks {
  margin: 0;
  font-family: var(--display); font-style: italic; font-size: 0.95rem;
  color: var(--slate); line-height: 1.45;
}
.pc-unlocks b { font-weight: 600; color: var(--ink); font-style: normal; }

.pc-form { display: grid; gap: 14px; }
.pc-field { display: flex; flex-direction: column; gap: 6px; }
.pc-field label {
  font-family: var(--sans); font-size: 0.74rem; font-weight: 800;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink);
}
.pc-req {
  margin-left: 6px;
  font-family: var(--sans); font-size: 0.62rem; font-style: normal;
  color: var(--champagne-deep); font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
}
.pc-field input,
.pc-field select,
.pc-field textarea {
  min-height: 40px;
  padding: 9px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: 8px;
  background: white;
  color: var(--ink);
  font-family: var(--body); font-size: 0.96rem;
  transition: border-color 180ms, box-shadow 180ms;
}
.pc-field textarea { min-height: 80px; resize: vertical; line-height: 1.5; font-family: var(--display); }
.pc-field input:focus, .pc-field select:focus, .pc-field textarea:focus {
  outline: 0; border-color: var(--forest); box-shadow: 0 0 0 4px rgba(15,61,52,0.08);
}
.pc-help { color: var(--slate); font-size: 0.78rem; line-height: 1.4; font-style: italic; }

/* Repeating sections */
.pc-repeating { display: grid; gap: 14px; }
.pc-row {
  padding: 16px 18px;
  border: 1px solid var(--hairline);
  border-radius: 10px;
  background: rgba(250,248,243,0.6);
}
.pc-row > header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--hairline);
}
.pc-row > header strong {
  font-family: var(--sans); font-size: 0.84rem; color: var(--ink); font-weight: 800;
}
.pc-row-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.pc-add {
  align-self: flex-start;
}
.pc-empty {
  color: var(--mauve); font-style: italic; font-family: var(--display);
  text-align: center; padding: 18px; border: 1px dashed var(--hairline-strong); border-radius: 8px;
}

.pc-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 28px;
  border-top: 1px solid var(--hairline);
  background: var(--paper);
}
.pc-autosave {
  font-family: var(--mono); font-size: 0.78rem; color: var(--slate);
  padding: 5px 12px; border-radius: 999px;
  background: rgba(15,61,52,0.08); border: 1px solid var(--hairline);
}
.pc-foot-actions { display: flex; gap: 8px; }
.pc-foot-actions button[disabled] { opacity: 0.4; pointer-events: none; }

/* Personalization CTA on Drafter preview */
.fp-personalization-cta {
  display: flex; justify-content: space-between; align-items: center;
  gap: 18px; flex-wrap: wrap;
  margin-top: 10px;
  padding: 14px 18px;
  border: 1px solid var(--champagne);
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(161,132,74,0.08), rgba(255,255,255,0.92));
}
.fp-personalization-cta strong {
  display: block; font-family: var(--sans); font-size: 0.88rem; color: var(--ink); font-weight: 800;
  margin-bottom: 2px;
}
.fp-personalization-cta span {
  display: block; font-size: 0.84rem; color: var(--slate);
}
.fp-personalization-cta code {
  font-family: var(--mono); font-size: 0.8rem;
  background: rgba(11,11,12,0.06); padding: 1px 5px; border-radius: 3px;
}

@media (max-width: 900px) {
  .pc-body { grid-template-columns: 1fr; }
  .pc-row-form { grid-template-columns: 1fr; }
  .pc-hero-card { flex-direction: column; align-items: flex-start; }
}

/* ── Opportunity picker (universal) ── */
.picker-filters {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 10px;
  margin-bottom: 14px;
}
.picker-filters input,
.picker-filters select {
  min-height: 42px;
  padding: 0 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: 999px;
  background: white;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.88rem;
  font-weight: 500;
}
.picker-filters input:focus, .picker-filters select:focus {
  outline: 0; border-color: var(--forest); box-shadow: 0 0 0 4px rgba(15,61,52,0.08);
}
.picker-list {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 6px;
  max-height: 56vh; overflow-y: auto;
  padding-right: 4px;
}
.picker-row {
  display: grid;
  grid-template-columns: 72px 56px minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--hairline);
  border-radius: 10px;
  background: rgba(255,255,255,0.96);
  cursor: pointer;
  transition: background 180ms, border-color 180ms, transform 180ms;
}
.picker-row:hover { background: white; border-color: rgba(15,61,52,0.32); transform: translateY(-1px); }
.picker-days {
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
  padding: 5px 10px; border-radius: 999px;
  text-align: center;
}
.picker-days.urgent { background: rgba(140,42,42,0.12); color: #8c2a2a; }
.picker-days.soon   { background: rgba(161,132,74,0.18); color: var(--champagne-deep); }
.picker-days.ok     { background: rgba(15,61,52,0.10); color: var(--forest); }
.picker-days.unk    { background: var(--paper); color: var(--slate); }
.picker-pri {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.1em; text-align: center;
  padding: 4px 8px; border-radius: 999px;
}
.picker-pri.high { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.picker-pri.med  { background: rgba(15,61,52,0.10); color: var(--forest); }
.picker-pri.low  { background: rgba(74,74,82,0.08); color: var(--slate); }
.picker-pri.unk  { background: var(--paper); color: var(--mauve); }
.picker-body { min-width: 0; }
.picker-body strong {
  display: block;
  font-family: var(--sans); font-size: 0.92rem; font-weight: 700;
  color: var(--ink); line-height: 1.25;
}
.picker-body span {
  display: block;
  color: var(--slate); font-size: 0.82rem; line-height: 1.4;
  margin-top: 2px;
}
.t-brand.empty { background: var(--paper); color: var(--mauve); }
.picker-actions { display: flex; gap: 6px; }
.picker-empty {
  padding: 30px;
  text-align: center;
  color: var(--mauve);
  font-style: italic;
  font-family: var(--display);
  border: 1px dashed var(--hairline-strong);
  border-radius: 10px;
}

/* ── Opportunity dossier ── */
.dossier-deadline {
  text-align: right;
  padding: 12px 18px;
  border-radius: 12px;
  background: var(--paper);
  min-width: 110px;
}
.dossier-deadline strong {
  display: block;
  font-family: var(--display); font-size: 2.2rem; font-weight: 300;
  color: var(--ink); line-height: 1; letter-spacing: -0.018em;
}
.dossier-deadline strong em {
  display: block; font-style: normal;
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--slate);
  margin-top: 4px;
}
.dossier-deadline span {
  display: block; font-family: var(--mono); font-size: 0.76rem;
  color: var(--slate); margin-top: 6px;
}
.dossier-deadline.urgent { background: rgba(140,42,42,0.10); }
.dossier-deadline.urgent strong { color: #8c2a2a; }
.dossier-deadline.soon   { background: rgba(161,132,74,0.16); }
.dossier-deadline.soon strong   { color: var(--champagne-deep); }
.dossier-deadline.ok     { background: rgba(15,61,52,0.10); }
.dossier-deadline.ok strong     { color: var(--forest); }
.dossier-deadline.past   { background: rgba(74,74,82,0.10); }
.dossier-deadline.past strong   { color: var(--slate); text-decoration: line-through; }

.dossier-meta {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 18px;
  padding: 14px 16px;
  border-radius: 10px;
  background: var(--paper);
}
.dossier-meta > div { display: flex; flex-direction: column; gap: 4px; }
.dossier-meta span {
  font-family: var(--sans); font-size: 0.64rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--champagne-deep);
}
.dossier-meta b {
  font-family: var(--sans); font-size: 0.84rem; color: var(--ink); font-weight: 700;
}
.dossier-meta b.t-priority { display: inline-block; }

.dossier-verify {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 14px 16px;
  margin: 14px 0;
  border-radius: 10px;
  background: rgba(140,42,42,0.06);
  border-left: 3px solid #8c2a2a;
}
.dossier-verify .t-verify { background: rgba(140,42,42,0.18); flex-shrink: 0; }
.dossier-verify p { margin: 0; color: var(--ink); font-size: 0.9rem; line-height: 1.5; }
.dossier-verify b { color: #8c2a2a; }

.dossier-links {
  display: flex; gap: 10px; flex-wrap: wrap;
  margin-bottom: 12px;
}

@media (max-width: 900px) {
  .picker-filters { grid-template-columns: 1fr 1fr; }
  .picker-row { grid-template-columns: 60px 48px 1fr; }
  .picker-row .t-brand, .picker-row .picker-actions { grid-column: 1 / -1; }
  .dossier-meta { grid-template-columns: 1fr 1fr; }
}

/* ── Floating global action bar ── */
.fp-action-bar {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%);
  z-index: 80;
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--ink), var(--forest-deep));
  box-shadow: 0 28px 56px rgba(11,11,12,0.4);
  animation: ddSlideUp 320ms cubic-bezier(.2,.7,.2,1);
}
.fp-action-bar button {
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--bone);
}
.fp-action-bar button:hover {
  background: rgba(255,255,255,0.16);
  color: var(--bone);
}
.fp-action-bar .primary-action {
  background: linear-gradient(135deg, var(--champagne), var(--champagne-deep));
  color: var(--ink); border-color: transparent;
}
.fp-action-bar .primary-action:hover {
  filter: brightness(1.08);
}
.fp-action-bar .text-action {
  background: transparent; border-color: transparent; color: rgba(250,248,243,0.78);
}
.fp-action-bar .text-action:hover { background: rgba(255,255,255,0.08); color: var(--bone); }

/* Activity feed scoped to founder portal (slightly tighter) */
.fp-activity-section { margin: 18px 0 28px; }

@media (max-width: 720px) {
  .fp-budget-summary { grid-template-columns: 1fr 1fr; }
  .fp-action-bar { width: calc(100% - 32px); left: 16px; right: 16px; transform: none; flex-wrap: wrap; justify-content: center; }
}

/* ═════════════════════════════════════════════════════════════════════
   PERSONAL DASHBOARD (dashboard.html)
   ═════════════════════════════════════════════════════════════════════ */
.personal-body {
  background:
    radial-gradient(circle at 85% 4%, rgba(161, 132, 74, 0.14), transparent 32%),
    radial-gradient(circle at 6% 94%, rgba(15, 61, 52, 0.10), transparent 36%),
    linear-gradient(180deg, rgba(250, 248, 243, 0.98), rgba(242, 237, 229, 0.78)),
    var(--bone);
}
.personal-shell {
  grid-template-columns: minmax(0, 1fr);
  width: min(1280px, calc(100% - 64px));
}
.personal-masthead {
  position: sticky;
  top: 0;
  z-index: 30;
  display: grid;
  grid-template-columns: minmax(220px, 0.5fr) minmax(0, 1.4fr) auto;
  align-items: center;
  gap: 18px;
  padding: 14px 0;
  margin-bottom: 8px;
  border-bottom: 1px solid var(--hairline);
  background: rgba(250, 248, 243, 0.94);
  backdrop-filter: blur(18px);
}
.personal-nav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 4px;
  padding: 5px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.6), 0 4px 14px rgba(11,11,12,0.04);
}
.personal-nav a {
  padding: 8px 14px;
  border-radius: var(--r-pill);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 700;
  transition: all 180ms;
}
.personal-nav a:hover { background: rgba(15,61,52,0.08); color: var(--forest); }

.personal-main { min-width: 0; padding: 24px 0 80px; }

.personal-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(320px, 0.6fr);
  gap: 28px;
  align-items: end;
  margin: 16px 0 28px;
  padding: 32px 0 28px;
  border-bottom: 1px solid var(--hairline);
}
.hero-greeting { min-width: 0; }
.hero-greeting h1 {
  font-size: clamp(2.6rem, 5vw, 4.2rem);
  font-weight: 300;
  line-height: 1;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin-bottom: 12px;
}
.hero-greeting .hero-copy {
  margin: 8px 0 0;
  font-family: var(--display);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--slate);
  line-height: 1.5;
}

.hero-hotlist {
  padding: 24px;
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 95% 10%, rgba(161,132,74,0.2), transparent 50%),
    linear-gradient(150deg, var(--ink) 0%, var(--forest-deep) 100%);
  color: var(--bone);
  box-shadow: var(--shadow-hover);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.hero-hotlist header {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.16);
}
.hotlist-tag {
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--champagne);
}
.hotlist-count {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: rgba(250,248,243,0.7);
  padding: 3px 9px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.08);
}
.hotlist {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 10px;
  counter-reset: hot;
}
.hotlist li {
  display: grid;
  grid-template-columns: 50px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(255,255,255,0.12);
}
.hotlist li:last-child { border-bottom: 0; }
.hot-days {
  font-family: var(--mono);
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--champagne);
  text-align: center;
  padding: 4px 8px;
  border-radius: var(--r-pill);
  background: rgba(161,132,74,0.18);
}
.hot-meta { min-width: 0; }
.hot-meta strong {
  display: block;
  font-family: var(--display);
  font-size: 0.98rem;
  font-weight: 500;
  color: var(--bone);
  line-height: 1.18;
  letter-spacing: -0.005em;
}
.hot-meta span {
  display: block;
  font-size: 0.78rem;
  color: rgba(250,248,243,0.7);
  margin-top: 2px;
  line-height: 1.35;
}
.hotlist .t-link { color: var(--champagne); }
.hero-hotlist .ghost-action {
  margin-top: 6px;
  background: rgba(255,255,255,0.08);
  border-color: rgba(255,255,255,0.18);
  color: var(--bone);
}
.hero-hotlist .ghost-action:hover { background: rgba(255,255,255,0.16); color: var(--champagne); border-color: var(--champagne); }

.personal-kpis { margin-bottom: 28px; }

.personal-section {
  margin: 36px 0 18px;
  padding: 32px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-card);
}
.personal-section .section-head { margin-bottom: 18px; }
.personal-section .tracker-panel {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.brand-columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.brand-col {
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: white;
  display: flex; flex-direction: column; gap: 12px;
}
.brand-col:nth-child(1) { border-top: 4px solid var(--plum); }
.brand-col:nth-child(2) { border-top: 4px solid var(--forest-glow); }
.brand-col:nth-child(3) { border-top: 4px solid var(--forest); }
.brand-col header {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--hairline);
}
.brand-col h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: none;
}
.brand-col-count {
  font-family: var(--mono);
  font-size: 0.84rem;
  color: var(--slate);
  padding: 3px 9px;
  border-radius: var(--r-pill);
  background: var(--paper);
}
.brand-col > p { margin: 0; color: var(--slate); font-size: 0.84rem; line-height: 1.45; }
.brand-items {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 10px;
}
.brand-items li {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-sm);
  background: rgba(250,248,243,0.6);
}
.brand-item-head { display: flex; gap: 6px; align-items: center; }
.brand-items strong {
  font-family: var(--sans);
  font-size: 0.88rem;
  font-weight: 800;
  color: var(--ink);
  line-height: 1.25;
}
.brand-items span { color: var(--slate); font-size: 0.8rem; line-height: 1.4; }
.brand-items em {
  font-style: italic;
  color: var(--ink);
  font-size: 0.78rem;
  line-height: 1.4;
  margin-top: 4px;
  padding: 6px 8px;
  border-radius: var(--r-sm);
  background: rgba(161,132,74,0.08);
}
.brand-empty { color: var(--mauve); font-style: italic; text-align: center; padding: 18px; }

/* Deadline timeline */
.deadline-timeline { display: grid; gap: 22px; }
.tl-group h4 {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px;
  font-family: var(--display);
  font-size: 1.1rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--ink);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--hairline);
}
.tl-group h4 em {
  font-style: normal;
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--slate);
  padding: 2px 8px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
}
.tl-group ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
.tl-group li {
  display: grid;
  grid-template-columns: 150px minmax(0, 1.2fr) minmax(0, 2fr) auto auto auto;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-sm);
  background: white;
  font-size: 0.86rem;
  transition: background 180ms;
}
.tl-group li:hover { background: rgba(15,61,52,0.04); }
.tl-date {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--ink);
  display: flex; flex-direction: column;
}
.tl-date em { font-style: normal; color: var(--champagne-deep); font-size: 0.72rem; font-weight: 700; }
.tl-group strong {
  font-family: var(--sans);
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--ink);
}
.tl-prog { color: var(--slate); font-size: 0.82rem; line-height: 1.35; }

/* Wins */
.wins-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.win-card {
  padding: 22px;
  border: 1px solid var(--hairline);
  border-left: 4px solid var(--forest);
  border-radius: var(--r-md);
  background: white;
  display: flex; flex-direction: column; gap: 8px;
}
.win-card header { display: flex; align-items: center; gap: 10px; }
.win-card header small { font-family: var(--mono); color: var(--slate); font-size: 0.78rem; }
.win-card strong {
  font-family: var(--display);
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.win-card p { margin: 0; color: var(--slate); font-size: 0.9rem; line-height: 1.5; }
.win-card small { color: var(--mauve); font-size: 0.78rem; line-height: 1.4; }
.win-next {
  margin-top: 8px;
  padding: 10px 12px;
  border-radius: var(--r-sm);
  background: rgba(15,61,52,0.06);
  color: var(--ink);
  font-size: 0.84rem;
}
.win-next span {
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--forest);
}
.win-next em { font-style: normal; color: var(--champagne-deep); font-family: var(--mono); font-size: 0.78rem; }
.win-card footer { margin-top: auto; padding-top: 8px; border-top: 1px dashed var(--hairline); }

.personal-footer {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap;
  gap: 18px;
  margin-top: 48px;
  padding: 28px 0 0;
  border-top: 1px solid var(--hairline);
  color: var(--slate);
}
.personal-footer strong {
  display: block;
  font-family: var(--sans);
  font-size: 0.96rem;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 4px;
}
.personal-footer p { margin: 0; font-size: 0.82rem; max-width: 360px; }
.personal-footer-links { display: flex; gap: 14px; }
.personal-footer-links a {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink);
  padding: 8px 14px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  transition: all 180ms;
}
.personal-footer-links a:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }

@media (max-width: 1280px) {
  .brand-columns { grid-template-columns: 1fr; }
  .personal-hero { grid-template-columns: 1fr; }
  .tl-group li { grid-template-columns: 1fr; gap: 4px; padding: 14px; }
  .wins-grid { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .personal-masthead { grid-template-columns: 1fr; gap: 12px; }
  .personal-nav { width: 100%; justify-content: flex-start; overflow-x: auto; }
  .personal-section { padding: 22px; }
}

/* ───────── Personal dashboard · premium upgrades ───────── */
.studio-section .section-head, .desk-team-section .section-head, .intel-section .section-head {
  align-items: flex-end;
}
.studio-quick-actions { display:flex; gap:8px; flex-wrap:wrap; }

.studio-layout {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.studio-draft {
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  transition: transform 200ms, box-shadow 200ms;
}
.studio-draft:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.studio-draft.ready    { border-top: 4px solid var(--forest); }
.studio-draft.drafting { border-top: 4px solid var(--champagne); }
.studio-draft.active   { border-top: 4px solid var(--plum); }
.studio-draft header {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 8px; border-bottom: 1px solid var(--hairline);
}
.studio-state {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--r-pill);
}
.studio-state.ready    { background: rgba(15,61,52,0.14); color: var(--forest); }
.studio-state.drafting { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.studio-state.active   { background: rgba(59,42,66,0.16); color: var(--plum); }
.studio-draft strong {
  font-family: var(--display); font-size: 1.18rem; font-weight: 500;
  letter-spacing: -0.005em; line-height: 1.18; color: var(--ink);
}
.studio-desc { margin: 0; color: var(--slate); font-size: 0.84rem; line-height: 1.45; }
.studio-doc {
  padding: 14px;
  border-radius: var(--r-sm);
  background: var(--paper);
  border-left: 2px solid var(--champagne);
}
.studio-doc p {
  font-family: var(--display); font-size: 0.92rem; line-height: 1.55;
  color: var(--ink); margin: 0 0 8px;
}
.studio-doc p:last-child { margin: 0; }
.studio-doc b { font-weight: 600; color: var(--ink); }
.studio-meta {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px;
  padding: 10px 0; border-top: 1px dashed var(--hairline); border-bottom: 1px dashed var(--hairline);
}
.studio-meta > div { display: flex; flex-direction: column; gap: 2px; }
.studio-meta .meta-l { font-family: var(--sans); font-size: 0.62rem; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--champagne-deep); }
.studio-meta b { font-family: var(--mono); font-size: 0.94rem; color: var(--ink); font-weight: 700; }
.studio-workflows {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.workflow-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: rgba(15,61,52,0.08);
  color: var(--forest);
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.studio-footer {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: auto; padding-top: 8px;
}
.studio-workflow-trace {
  margin-top: 18px; padding: 12px 16px;
  display: flex; align-items: center; gap: 12px;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.6);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.84rem;
}
.studio-workflow-trace .dot.pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: #56e0a8;
  box-shadow: 0 0 0 0 rgba(86,224,168,0.6);
  animation: pulse 1.8s ease-out infinite;
  display: inline-block;
}
.studio-workflow-trace b { color: var(--ink); font-weight: 800; }

/* ─── Desk team grid ─── */
.desk-team-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.desk-team-card {
  display: flex; flex-direction: column; gap: 10px;
  padding: 18px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.96);
  transition: transform 200ms, box-shadow 200ms;
}
.desk-team-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card); }
.desk-team-card header {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
}
.desk-team-card h3 {
  font-family: var(--display); font-size: 1.05rem; font-weight: 500;
  letter-spacing: -0.005em; line-height: 1.18; color: var(--ink);
  text-transform: none;
}
.desk-team-card p { margin: 0; color: var(--slate); font-size: 0.84rem; line-height: 1.42; }
.desk-team-card .desk-state { font-size: 0.66rem; letter-spacing: 0.06em; color: var(--slate); }
.desk-team-card.live .desk-state { color: #15573d; }
.desk-team-card.warm .desk-state { color: var(--champagne-deep); }
.desk-stat {
  margin-top: auto; padding-top: 10px;
  border-top: 1px dashed var(--hairline);
  font-family: var(--mono); font-size: 0.78rem; color: var(--slate);
}
.desk-stat b { color: var(--ink); font-weight: 700; }

/* ─── Intel feed (personal) ─── */
.intel-feed {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.intel-card-personal {
  display: flex; flex-direction: column; gap: 10px;
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.94);
  text-decoration: none; color: inherit;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
  position: relative; overflow: hidden;
}
.intel-card-personal:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-card);
  border-color: rgba(15,61,52,0.32);
}
.intel-card-personal header {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 4px;
}
.intel-tag {
  font-family: var(--sans); font-size: 0.66rem; font-weight: 800;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 3px 9px; border-radius: var(--r-pill);
  background: rgba(15,61,52,0.1); color: var(--forest);
}
.intel-card-personal.flagship .intel-tag { background: var(--ink); color: var(--champagne); }
.intel-card-personal.briefing .intel-tag { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.intel-card-personal.deal .intel-tag { background: rgba(59,42,66,0.14); color: var(--plum); }
.intel-card-personal.donor .intel-tag { background: rgba(107,128,115,0.16); color: #3f5247; }
.intel-date { font-family: var(--mono); font-size: 0.72rem; color: var(--slate); }
.intel-card-personal h3 {
  font-family: var(--display); font-size: 1.25rem; font-weight: 500;
  letter-spacing: -0.008em; line-height: 1.22; color: var(--ink);
  text-transform: none; margin: 0;
}
.intel-card-personal p { margin: 0; color: var(--slate); font-size: 0.9rem; line-height: 1.55; }
.intel-card-personal.flagship {
  background: linear-gradient(165deg, var(--ink), #1a2c28); color: var(--bone);
  border-color: transparent;
}
.intel-card-personal.flagship h3 { color: var(--bone); }
.intel-card-personal.flagship p { color: rgba(250,248,243,0.82); }
.intel-card-personal.flagship .intel-date { color: rgba(250,248,243,0.6); }
.intel-card-personal.flagship .intel-cta { color: var(--champagne); }
.intel-cta {
  margin-top: auto; padding-top: 8px;
  font-family: var(--sans); font-size: 0.78rem; font-weight: 800;
  color: var(--forest); letter-spacing: 0.04em;
}

@media (max-width: 1280px) {
  .studio-layout { grid-template-columns: 1fr; }
  .desk-team-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .intel-feed { grid-template-columns: 1fr; }
}
@media (max-width: 900px) {
  .desk-team-grid { grid-template-columns: 1fr; }
}

/* ───────── Personal Tracker view (private) ───────── */
.nav-item-private .nav-pill.private {
  background: var(--ink);
  color: var(--champagne);
}
.tracker-view .section-head { align-items: flex-start; }
.tracker-private-tag {
  display: inline-flex; align-items: center;
  padding: 7px 14px;
  border-radius: var(--r-pill);
  background: rgba(11,11,12,0.06);
  border: 1px solid var(--hairline-strong);
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--ink);
  white-space: nowrap;
}
.tracker-kpis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}
.t-kpi {
  position: relative;
  padding: 18px 20px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.94);
  display: flex; flex-direction: column; gap: 6px;
  overflow: hidden;
}
.t-kpi-win { border-color: rgba(15,61,52,0.32); background: linear-gradient(160deg, rgba(15,61,52,0.06), rgba(255,255,255,0.94)); }
.t-kpi-hot { border-color: rgba(161,132,74,0.5); background: linear-gradient(160deg, rgba(161,132,74,0.1), rgba(255,255,255,0.94)); }
.t-kpi-short { border-color: rgba(59,42,66,0.32); background: linear-gradient(160deg, rgba(59,42,66,0.06), rgba(255,255,255,0.94)); }
.t-kpi-label {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--champagne-deep);
}
.t-kpi-num {
  font-family: var(--display);
  font-size: 2.4rem;
  font-weight: 300;
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--ink);
}
.t-kpi small { color: var(--slate); font-family: var(--sans); font-size: 0.72rem; }

.tracker-tabs {
  display: flex; flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
  padding: 6px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.6);
  width: fit-content;
  max-width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}
.t-tab {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  background: transparent;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.84rem;
  font-weight: 700;
  white-space: nowrap;
  transition: all 180ms;
}
.t-tab:hover { color: var(--ink); background: rgba(15,61,52,0.06); }
.t-tab.active { background: var(--ink); color: var(--bone); }
.t-tab em {
  font-style: normal;
  font-family: var(--mono);
  font-size: 0.7rem;
  padding: 1px 8px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.18);
}
.t-tab:not(.active) em { background: rgba(11,11,12,0.06); color: var(--slate); }

.tracker-panel {
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow-card);
}
.t-panel-sub {
  margin: 0 0 18px;
  color: var(--slate);
  font-size: 0.9rem;
  line-height: 1.5;
  max-width: 760px;
}

/* Action panel ── grouped urgency cards */
.t-action-group { margin-bottom: 22px; }
.t-action-group h3 {
  display: flex; align-items: center; gap: 10px;
  margin: 0 0 10px;
  font-family: var(--display);
  font-size: 1.1rem;
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.t-action-group h3 em {
  font-style: normal;
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--slate);
  padding: 2px 8px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-pill);
}
.t-action-group.critical h3 { color: #8c2a2a; }
.t-action-group.urgent h3 { color: var(--champagne-deep); }
.t-action-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.t-action-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 16px;
  border: 1px solid var(--hairline);
  border-left: 3px solid var(--champagne);
  border-radius: var(--r-md);
  background: white;
  transition: transform 180ms, box-shadow 180ms;
}
.t-action-card:hover { transform: translateY(-1px); box-shadow: var(--shadow-soft); }
.critical .t-action-card { border-left-color: #8c2a2a; }
.urgent .t-action-card { border-left-color: var(--champagne-deep); }
.soon .t-action-card { border-left-color: var(--forest); }
.rolling .t-action-card { border-left-color: var(--mauve); }
.t-action-head { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.t-action-card strong {
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.005em;
  color: var(--ink);
}
.t-action-card p { margin: 0; color: var(--slate); font-size: 0.86rem; line-height: 1.45; }
.t-action-card small { color: var(--mauve); font-size: 0.78rem; line-height: 1.4; }
.t-action-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 4px;
  padding-top: 8px;
  border-top: 1px dashed var(--hairline);
}
.t-action-src {
  font-family: var(--mono);
  font-size: 0.66rem;
  color: var(--slate);
  margin-left: auto;
}

/* Badges */
.t-priority {
  font-family: var(--sans);
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
.t-priority.high { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.t-priority.med { background: rgba(15,61,52,0.12); color: var(--forest); }
.t-priority.low { background: rgba(74,74,82,0.1); color: var(--slate); }
.t-priority.unk { background: var(--paper); color: var(--mauve); }

.t-status {
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  padding: 3px 8px;
  border-radius: var(--r-pill);
  white-space: nowrap;
}
.t-status.won { background: rgba(15,61,52,0.18); color: var(--forest-deep); }
.t-status.rejected { background: rgba(140,42,42,0.12); color: #8c2a2a; }
.t-status.draft { background: rgba(161,132,74,0.2); color: var(--champagne-deep); }
.t-status.short { background: rgba(59,42,66,0.14); color: var(--plum); }
.t-status.submitted { background: rgba(74,74,82,0.08); color: var(--slate); text-transform: lowercase; }
.t-status.muted { background: var(--paper); color: var(--mauve); }

.t-days {
  font-family: var(--mono);
  font-size: 0.74rem;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
.t-days.today, .t-days.urgent { background: rgba(140,42,42,0.1); color: #8c2a2a; }
.t-days.soon { background: rgba(161,132,74,0.18); color: var(--champagne-deep); }
.t-days.ok { background: rgba(15,61,52,0.08); color: var(--forest); }
.t-days.past { background: rgba(74,74,82,0.08); color: var(--slate); text-decoration: line-through; }
.t-days.unk { background: var(--paper); color: var(--slate); }

.t-brand {
  display: inline-block;
  padding: 3px 9px;
  border-radius: var(--r-pill);
  background: rgba(15,61,52,0.08);
  color: var(--forest);
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 700;
  white-space: nowrap;
}
.t-link {
  font-family: var(--sans);
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--forest);
  white-space: nowrap;
}
.t-link:hover { text-decoration: underline; }
.t-link.muted { color: var(--mauve); font-style: italic; font-weight: 500; }

/* "To Submit" button · distinct from "donor site" link */
.t-link.t-submit {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 9px;
  border-radius: 999px;
  background: var(--champagne);
  color: var(--ink);
  border: 1px solid var(--champagne-deep);
  transition: background 180ms, transform 180ms;
}
.t-link.t-submit:hover {
  background: var(--champagne-deep);
  color: var(--bone);
  text-decoration: none;
  transform: translateY(-1px);
}

/* "Verify" flag · for entries where Funder inference is ambiguous */
.t-verify {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(140, 42, 42, 0.12);
  color: #8c2a2a;
  font-size: 0.74rem;
  cursor: help;
  margin-left: 4px;
}
.t-verify:hover { background: rgba(140, 42, 42, 0.22); }

/* Tables */
.t-table-wrap { overflow-x: auto; border: 1px solid var(--hairline); border-radius: var(--r-md); background: white; }
.t-table { width: 100%; border-collapse: collapse; font-family: var(--sans); font-size: 0.84rem; }
.t-table thead { background: var(--paper); }
.t-table th {
  padding: 11px 12px;
  text-align: left;
  color: var(--ink);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--hairline-strong);
  white-space: nowrap;
}
.t-table td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--hairline);
  color: var(--slate);
  vertical-align: top;
}
.t-table tbody tr:hover { background: rgba(15,61,52,0.04); }
.t-table tbody tr:last-child td { border-bottom: 0; }
.t-table .t-cell-org { color: var(--ink); font-weight: 700; min-width: 180px; }
.t-table .t-cell-prog strong { display: block; color: var(--ink); font-weight: 700; margin-bottom: 3px; font-family: var(--sans); font-size: 0.86rem; }
.t-table .t-cell-prog small { display: block; color: var(--slate); font-size: 0.76rem; line-height: 1.4; }
.t-table .t-cell-num { font-family: var(--mono); color: var(--mauve); font-size: 0.78rem; }
.t-table .t-cell-type { font-size: 0.78rem; }
.t-table .muted { color: var(--mauve); font-size: 0.76rem; }

.t-filters {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin-bottom: 14px;
}
.t-filters label {
  display: grid; gap: 5px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.t-filters select {
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  background: white;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.82rem;
  text-transform: none;
  letter-spacing: 0;
  font-weight: 400;
}
.t-count {
  margin-left: auto;
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--slate);
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--paper);
}

/* Donor network grid */
.t-donor-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.t-donor-card {
  padding: 18px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: white;
  display: flex; flex-direction: column; gap: 10px;
  transition: transform 180ms, box-shadow 180ms, border-color 180ms;
}
.t-donor-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-soft); border-color: rgba(15,61,52,0.24); }
.t-donor-card.iwhf { border-left: 3px solid var(--forest); }
.t-donor-card.iwhf-elle { border-left: 3px solid var(--champagne); }
.t-donor-card.elle-international { border-left: 3px solid var(--plum); }
.t-donor-card.insideher { border-left: 3px solid var(--forest-glow); }
.t-donor-card.neither-priority { border-left: 3px solid var(--mauve); opacity: 0.75; }
.t-donor-card header { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.t-donor-card strong {
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.16;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.t-donor-meta {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 5px;
  font-size: 0.78rem;
  color: var(--slate);
  line-height: 1.4;
}
.t-donor-meta b {
  display: inline-block;
  min-width: 70px;
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.t-donor-angle {
  margin: 0;
  padding: 10px 12px;
  border-radius: var(--r-sm);
  background: var(--paper);
  color: var(--ink);
  font-style: italic;
  font-size: 0.82rem;
  line-height: 1.45;
}
.t-donor-card footer { margin-top: auto; padding-top: 8px; border-top: 1px dashed var(--hairline); }

@media (max-width: 1280px) {
  .tracker-kpis { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .t-action-list { grid-template-columns: 1fr; }
  .t-donor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .tracker-kpis { grid-template-columns: 1fr 1fr; }
  .t-donor-grid { grid-template-columns: 1fr; }
  .tracker-panel { padding: 18px; }
  .tracker-view .section-head { flex-direction: column; }
  .tracker-private-tag { align-self: flex-start; }
}

/* ───────── Sectors view (TAM expansion) ───────── */
.filter-grid-6 {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.nav-item-new {
  position: relative;
  padding-right: 36px !important;
}
.nav-pill {
  position: absolute;
  top: 50%; right: 10px;
  transform: translateY(-50%);
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: var(--champagne);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.nav-item.active .nav-pill { background: var(--champagne); color: var(--ink); }

.sectors-view .section-sub { max-width: 720px; }

.sector-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 22px;
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 5% 5%, rgba(15,61,52,0.06), transparent 50%),
    rgba(255,255,255,0.92);
  box-shadow: var(--shadow-card);
}
.sector-summary div { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.sector-summary b {
  font-family: var(--display);
  font-size: 2.1rem;
  font-weight: 300;
  letter-spacing: -0.01em;
  color: var(--ink);
  line-height: 1;
}
.sector-summary span {
  font-family: var(--sans);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}

.sector-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 24px;
}
.sector-tile {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-start;
  padding: 22px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.92);
  text-align: left;
  cursor: pointer;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms, background 200ms;
  overflow: hidden;
}
.sector-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, rgba(15,61,52,0.06), transparent 60%);
  opacity: 0;
  transition: opacity 200ms;
  pointer-events: none;
}
.sector-tile:hover {
  transform: translateY(-3px);
  border-color: rgba(15,61,52,0.32);
  box-shadow: var(--shadow-hover);
  background: white;
}
.sector-tile:hover::after { opacity: 1; }
.sector-icon {
  display: inline-grid; place-items: center;
  width: 38px; height: 38px;
  border-radius: var(--r-pill);
  background: var(--paper);
  font-size: 1.1rem;
  margin-bottom: 4px;
}
.sector-tile strong {
  font-family: var(--display);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.18;
  color: var(--ink);
}
.sector-tile p { margin: 0; color: var(--slate); font-size: 0.84rem; line-height: 1.42; }
.sector-stats {
  display: flex; gap: 14px;
  margin-top: 4px;
  font-family: var(--mono);
  font-size: 0.74rem;
  color: var(--slate);
}
.sector-stats b { color: var(--ink); font-weight: 700; }
.sector-cta {
  font-style: normal;
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: var(--forest);
  margin-top: auto;
  padding-top: 6px;
}

.sector-note {
  padding: 18px 22px;
  border: 1px dashed var(--hairline-strong);
  border-radius: var(--r-md);
  background: rgba(242, 237, 229, 0.62);
}
.sector-note p { margin: 4px 0 0; color: var(--slate); font-size: 0.86rem; line-height: 1.5; }

/* Relevance badge (used by app.js renderOpportunityRow) */
.badge.relevance {
  background: rgba(11,11,12,0.08);
  color: var(--ink);
}

@media (max-width: 1280px) {
  .sector-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .filter-grid-6 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .sector-grid, .sector-summary, .filter-grid-6 { grid-template-columns: 1fr; }
  .nav-item-new { padding-right: 14px !important; }
  .nav-pill { position: static; transform: none; margin-left: 6px; }
}

/* ───────── Desk control center ───────── */
.desk-center {
  margin: 56px 0 36px;
  padding: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 95% 5%, rgba(15,61,52,0.06), transparent 40%),
    radial-gradient(circle at 5% 95%, rgba(161,132,74,0.05), transparent 40%),
    rgba(255,255,255,0.7);
  box-shadow: var(--shadow-card);
}
.desk-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.desk-card {
  position: relative;
  padding: 18px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.96);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
}
.desk-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-hover); border-color: rgba(15,61,52,0.22); }
.desk-card header {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--sans); font-size: 0.7rem; font-weight: 800;
}
.desk-tag {
  padding: 3px 9px;
  border-radius: var(--r-pill);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--paper);
  color: var(--slate);
}
.desk-tag.intel { background: rgba(15,61,52,0.12); color: var(--forest); }
.desk-tag.match { background: rgba(161,132,74,0.16); color: var(--champagne-deep); }
.desk-tag.draft { background: rgba(43,27,46,0.1); color: var(--plum); }
.desk-tag.trust { background: rgba(11,11,12,0.08); color: var(--ink); }
.desk-tag.editorial { background: rgba(107,128,115,0.16); color: #3f5247; }
.desk-tag.growth { background: rgba(15,61,52,0.08); color: var(--forest-glow); }
.desk-tag.revenue { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.desk-state { font-size: 0.66rem; letter-spacing: 0.08em; color: var(--slate); }
.desk-card.live .desk-state { color: #15573d; }
.desk-card.warm .desk-state { color: var(--champagne-deep); }
.desk-card.cold .desk-state { color: var(--slate); }
.desk-card h3 {
  margin: 4px 0 2px;
  font-family: var(--display);
  font-size: 1.18rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1.16;
  color: var(--ink);
}
.desk-card p { margin: 0; color: var(--slate); font-size: 0.85rem; line-height: 1.45; }
.desk-meta {
  list-style: none; padding: 0; margin: 6px 0 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 6px;
  font-family: var(--mono); font-size: 0.72rem; color: var(--slate);
  border-top: 1px dashed var(--hairline);
  padding-top: 10px;
}
.desk-meta b { color: var(--ink); font-weight: 700; }

/* ───────── Intelligence reports ───────── */
.intel-board {
  margin: 36px 0;
}
.intel-feature {
  padding: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 90% 0%, rgba(161,132,74,0.18), transparent 40%),
    linear-gradient(150deg, var(--ink) 0%, #1a2e28 100%);
  color: var(--bone);
  box-shadow: var(--shadow-hover);
  margin-bottom: 18px;
}
.intel-feature h3 {
  margin: 12px 0 14px;
  color: var(--bone);
  font-family: var(--display);
  font-size: clamp(1.6rem, 2.4vw, 2.2rem);
  font-weight: 400;
  letter-spacing: -0.012em;
  line-height: 1.12;
}
.intel-feature p { max-width: 720px; color: rgba(250,248,243,0.84); line-height: 1.6; font-size: 1rem; }
.intel-meta { display: flex; gap: 14px; align-items: center; font-family: var(--sans); font-size: 0.72rem; color: rgba(250,248,243,0.7); letter-spacing: 0.06em; text-transform: uppercase; }
.intel-pill {
  padding: 5px 12px;
  border: 1px solid var(--champagne);
  border-radius: var(--r-pill);
  color: var(--champagne);
  font-weight: 800;
}
.intel-stats {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin: 26px 0 22px;
  padding: 22px 0;
  border-top: 1px solid rgba(255,255,255,0.14);
  border-bottom: 1px solid rgba(255,255,255,0.14);
}
.intel-stats strong {
  display: block;
  font-family: var(--display);
  font-size: 2.2rem;
  font-weight: 300;
  color: var(--bone);
  letter-spacing: -0.01em;
}
.intel-stats span {
  display: block;
  color: rgba(250,248,243,0.7);
  font-family: var(--sans);
  font-size: 0.74rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-top: 4px;
}
.intel-cta { display: flex; gap: 12px; align-items: center; }
.intel-cta .text-action { color: var(--bone); }
.intel-cta .text-action:hover { background: rgba(255,255,255,0.08); }

.intel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.intel-card {
  position: relative;
  padding: 24px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.94);
  transition: transform 200ms, box-shadow 200ms, border-color 200ms;
  overflow: hidden;
}
.intel-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); border-color: rgba(15,61,52,0.22); }
.intel-card h4 {
  margin: 12px 0 10px;
  font-family: var(--display);
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.008em;
  line-height: 1.22;
  text-transform: none;
}
.intel-card p { margin: 0 0 14px; color: var(--slate); line-height: 1.5; font-size: 0.92rem; }
.intel-foot { font-family: var(--sans); font-size: 0.72rem; color: var(--slate); letter-spacing: 0.04em; }
.intel-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.intel-badge.open { background: rgba(15,61,52,0.1); color: var(--forest); }
.intel-badge.lock { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.intel-badge.lock::before { content: "🔒"; font-size: 0.8em; }
.intel-badge.crown { background: var(--ink); color: var(--champagne); }
.intel-badge.crown::before { content: "♛"; font-size: 0.9em; }
.intel-card.pro { background: linear-gradient(170deg, rgba(255,255,255,0.94) 70%, rgba(161,132,74,0.08)); }
.intel-card.institutional {
  background: linear-gradient(170deg, var(--ink) 0%, #1a2e28 100%);
  color: var(--bone);
  border-color: transparent;
}
.intel-card.institutional h4 { color: var(--bone); }
.intel-card.institutional p { color: rgba(250,248,243,0.8); }
.intel-card.institutional .intel-foot { color: rgba(250,248,243,0.6); }

/* ───────── Proposal workspace ───────── */
.proposal-board {
  margin: 36px 0;
  padding: 36px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,0.78);
  box-shadow: var(--shadow-card);
}
.proposal-layout {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr) 260px;
  gap: 16px;
  align-items: stretch;
}
.proposal-rail, .proposal-side {
  min-width: 0;
  padding: 20px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.94);
}
.draft-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.draft-list li {
  padding: 12px 14px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-sm);
  background: rgba(250,248,243,0.6);
  cursor: pointer;
  transition: all 180ms;
}
.draft-list li:hover { border-color: var(--forest); background: white; }
.draft-list li.active { border-color: var(--ink); background: white; box-shadow: var(--shadow-soft); }
.draft-state {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  font-family: var(--sans);
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 7px;
}
.draft-state.in-review { background: rgba(161,132,74,0.2); color: var(--champagne-deep); }
.draft-state.drafting { background: rgba(15,61,52,0.12); color: var(--forest); }
.draft-state.queued { background: rgba(74,74,82,0.12); color: var(--slate); }
.draft-state.submitted { background: rgba(15,61,52,0.18); color: var(--forest-deep); }
.draft-list strong {
  display: block;
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 800;
  margin-bottom: 3px;
  color: var(--ink);
}
.draft-list em { font-style: normal; color: var(--slate); font-size: 0.78rem; }

.proposal-doc {
  min-width: 0;
  padding: 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: white;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.doc-head { display: flex; justify-content: space-between; gap: 14px; padding-bottom: 18px; border-bottom: 1px solid var(--hairline); }
.doc-kicker {
  display: block;
  color: var(--champagne-deep);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.doc-head h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: -0.012em;
  line-height: 1.16;
  color: var(--ink);
}
.doc-actions { display: flex; gap: 8px; align-self: flex-start; }
.doc-body p { color: var(--ink); font-family: var(--display); font-size: 1.02rem; line-height: 1.6; margin-bottom: 14px; }
.doc-body p strong { font-weight: 600; color: var(--ink); }
.doc-body .hl {
  background: rgba(161,132,74,0.18);
  padding: 0 4px;
  border-radius: 3px;
}
.desk-trace {
  margin-top: 10px;
  padding-top: 14px;
  border-top: 1px dashed var(--hairline);
  font-family: var(--mono) !important;
  font-size: 0.76rem !important;
  color: var(--slate) !important;
  display: flex; align-items: center; gap: 8px;
}
.trace-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #56e0a8;
  box-shadow: 0 0 0 3px rgba(86,224,168,0.16);
}

.fit-bar {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 10px 0 14px;
  border-bottom: 1px dashed var(--hairline);
}
.fit-bar:last-of-type { border-bottom: 0; }
.fit-bar em {
  grid-column: 1 / -1;
  font-style: normal;
  color: var(--slate);
  font-size: 0.78rem;
  font-family: var(--sans);
}
.fit-bar > span {
  position: relative;
  display: block;
  width: 100%;
  height: 6px;
  border-radius: var(--r-pill);
  background: var(--paper);
  overflow: hidden;
}
.fit-bar > span::after {
  content: "";
  position: absolute;
  inset: 0;
  width: var(--p);
  border-radius: var(--r-pill);
  background: linear-gradient(90deg, var(--forest), var(--champagne));
}
.fit-bar b {
  font-family: var(--mono);
  font-size: 0.86rem;
  color: var(--ink);
}
.mt { margin-top: 20px; }
.mini-budget {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--mono);
  font-size: 0.84rem;
}
.mini-budget td { padding: 9px 0; border-bottom: 1px dashed var(--hairline); color: var(--slate); }
.mini-budget td:last-child { text-align: right; color: var(--ink); font-weight: 700; }
.mini-budget tr.total td {
  border-bottom: 0;
  border-top: 1px solid var(--ink);
  padding-top: 12px;
  color: var(--ink);
  font-weight: 800;
}

/* ───────── Membership ───────── */
.membership {
  margin: 36px 0;
  padding: 40px 0;
}
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}
.price-card {
  display: flex;
  flex-direction: column;
  padding: 30px 26px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.94);
  box-shadow: var(--shadow-card);
  transition: transform 200ms, box-shadow 200ms;
}
.price-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); }
.price-card header { margin-bottom: 16px; }
.price-tier {
  display: inline-block;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  background: var(--paper);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.pro-tier { background: rgba(15,61,52,0.12); color: var(--forest); }
.inst-tier { background: rgba(161,132,74,0.22); color: var(--champagne-deep); }
.ent-tier { background: var(--ink); color: var(--champagne); }
.price-card h3 {
  font-family: var(--display);
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.16;
  margin-bottom: 6px;
}
.price-card header p { color: var(--slate); font-size: 0.86rem; line-height: 1.4; margin: 0; }
.price {
  margin: 14px 0 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--hairline);
}
.price span {
  font-family: var(--display);
  font-size: 2.4rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.price em { font-style: normal; color: var(--slate); font-family: var(--sans); font-size: 0.84rem; margin-left: 6px; }
.price-feats { list-style: none; padding: 0; margin: 0 0 22px; display: grid; gap: 9px; }
.price-feats li { color: var(--ink); font-size: 0.88rem; line-height: 1.4; }
.price-feats li.muted { color: var(--mauve); }
.price-card.pro { border-color: var(--forest); transform: translateY(-6px); box-shadow: 0 28px 64px rgba(15,61,52,0.18); position: relative; }
.price-card.pro::before {
  content: "Most popular";
  position: absolute;
  top: -12px; right: 18px;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  background: var(--forest);
  color: var(--bone);
  font-family: var(--sans);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.price-card.enterprise {
  background: linear-gradient(160deg, var(--ink) 0%, var(--forest-deep) 100%);
  color: var(--bone);
  border-color: transparent;
}
.price-card.enterprise h3, .price-card.enterprise .price span { color: var(--bone); }
.price-card.enterprise header p, .price-card.enterprise .price em { color: rgba(250,248,243,0.74); }
.price-card.enterprise .price-feats li { color: var(--bone); }
.price-card.enterprise .price { border-bottom-color: rgba(255,255,255,0.18); }
.price-card.enterprise .ghost-action { border-color: var(--champagne); color: var(--champagne); }
.price-card.enterprise .ghost-action:hover { background: var(--champagne); color: var(--ink); }

.guarantee {
  margin-top: 24px;
  padding: 22px 26px;
  display: flex;
  gap: 18px;
  align-items: center;
  border: 1px solid var(--champagne);
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(161,132,74,0.08), rgba(255,255,255,0.86));
}
.guarantee-mark {
  width: 48px; height: 48px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--champagne);
  color: white;
  font-size: 1.4rem;
  flex-shrink: 0;
}
.guarantee strong { color: var(--ink); font-family: var(--sans); font-size: 0.92rem; }
.guarantee p { margin: 4px 0 0; color: var(--slate); font-size: 0.9rem; line-height: 1.5; }

/* ───────── Testimonials ───────── */
.testimonials { margin: 36px 0; }
.quotes {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.quotes figure {
  margin: 0;
  padding: 28px;
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.92);
  box-shadow: var(--shadow-card);
}
.quotes blockquote {
  margin: 0 0 16px;
  font-family: var(--display);
  font-size: 1.15rem;
  font-weight: 400;
  font-style: italic;
  line-height: 1.42;
  color: var(--ink);
  letter-spacing: -0.005em;
}
.quotes blockquote::before {
  content: "“";
  display: block;
  font-size: 3rem;
  line-height: 0.5;
  margin-bottom: 12px;
  color: var(--champagne);
}
.quotes figcaption {
  font-family: var(--sans);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--slate);
  letter-spacing: 0.02em;
}

/* ───────── Newsletter ───────── */
.newsletter { margin: 36px 0; }
.newsletter-card {
  padding: 40px;
  border-radius: var(--r-xl);
  background:
    radial-gradient(circle at 90% 10%, rgba(161,132,74,0.22), transparent 50%),
    linear-gradient(150deg, var(--ink) 0%, var(--forest-deep) 100%);
  color: var(--bone);
  box-shadow: var(--shadow-hover);
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 32px;
  align-items: center;
}
.newsletter-card h2 { color: var(--bone); margin: 12px 0 0; }
.newsletter-card .eyebrow { color: var(--champagne); }
.newsletter-card .lede { color: rgba(250,248,243,0.78); }
.newsletter-form {
  display: grid;
  gap: 12px;
  align-content: center;
}
.newsletter-form input {
  min-height: 54px;
  padding: 0 20px;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.08);
  color: var(--bone);
  font-size: 0.95rem;
  outline: 0;
  transition: border-color 180ms, background 180ms;
}
.newsletter-form input::placeholder { color: rgba(250,248,243,0.5); }
.newsletter-form input:focus { border-color: var(--champagne); background: rgba(255,255,255,0.12); }
.newsletter-form button { min-height: 54px; font-size: 0.95rem; }
.newsletter-form small { color: rgba(250,248,243,0.62); font-family: var(--sans); font-size: 0.76rem; letter-spacing: 0.02em; }

/* ───────── Footer ───────── */
.site-footer {
  margin-top: 56px;
  padding-top: 36px;
  border-top: 1px solid var(--hairline);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.86rem;
}
.foot-grid {
  display: grid;
  grid-template-columns: 1.6fr repeat(4, 1fr);
  gap: 28px;
  margin-bottom: 28px;
}
.foot-grid > div:first-child p {
  margin-top: 8px;
  max-width: 280px;
  color: var(--slate);
  line-height: 1.5;
}
.foot-grid strong { font-family: var(--sans); font-size: 0.92rem; color: var(--ink); margin-left: 8px; }
.foot-grid ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 7px; }
.foot-grid li { color: var(--slate); cursor: pointer; transition: color 180ms; }
.foot-grid li:hover { color: var(--ink); }
.foot-rule {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  padding: 22px 0;
  border-top: 1px solid var(--hairline);
  color: var(--mauve);
  font-size: 0.78rem;
}

/* ───────── Compact ───────── */
body.compact { --inspector: 342px; }

/* ───────── Responsive ───────── */
@media (max-width: 1280px) {
  .desk-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .pricing-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .intel-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .foot-grid { grid-template-columns: 1.6fr 1fr 1fr; }
}
@media (max-width: 1180px) {
  .app-shell { grid-template-columns: minmax(0, 1fr); }
  .sidebar { grid-template-columns: 1fr; justify-items: start; }
  .nav-list { justify-content: flex-start; width: 100%; }
  .sidebar-note { justify-self: start; }
  .inspector { position: relative; top: auto; height: auto; padding: 0 0 56px; }
  .inspector-inner { height: auto; max-height: none; }
  .donor-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .proposal-layout { grid-template-columns: 1fr; }
  .metrics-strip { grid-template-columns: repeat(3, 1fr); }
  .metric-signal { grid-column: span 3; }
}
@media (max-width: 900px) {
  .app-shell { width: min(100% - 36px, 1280px); display: block; }
  .sidebar { padding: 12px 0; }
  .nav-list { border-radius: var(--r-md); justify-content: flex-start; }
  .workspace { padding: 28px 0 40px; }
  .topbar, .section-head { align-items: flex-start; flex-direction: column; }
  .topbar { grid-template-columns: 1fr; gap: 22px; }
  .hero-aside { justify-items: start; width: 100%; }
  .hero-seal-wrap { width: 100px; height: 100px; }
  h1 { font-size: clamp(2.1rem, 10vw, 3.2rem); line-height: 1.04; }
  .metrics-strip, .filter-grid, .alert-builder, .map-panel,
  .pricing-grid, .quotes, .desk-grid, .intel-grid, .search-row,
  .newsletter-card, .foot-grid { grid-template-columns: 1fr; }
  .opportunity-row { grid-template-columns: 1fr; }
  .donor-grid { grid-template-columns: 1fr; }
  .map-canvas { min-height: 520px; }
  .map-region { width: calc(100% - 32px); left: 16px !important; }
  .metric-signal { grid-column: span 1; }
  .intel-stats { grid-template-columns: repeat(2, 1fr); }
  .desk-center, .intel-feature, .proposal-board, .newsletter-card { padding: 24px; }
  .proposal-board { overflow: hidden; }
  .proposal-layout > * { min-width: 0; }
  .draft-list strong, .doc-head, .doc-body, .doc-body p, .desk-trace { overflow-wrap: anywhere; }
  .price-card.pro { transform: none; }
}
@media (max-width: 620px) {
  .app-shell { width: min(100% - 24px, 1280px); }
  .product-brand {
    grid-template-columns: 54px minmax(0, 1fr);
    gap: 14px;
  }
  .product-brand .brand-mark,
  .product-brand .brand-mark img {
    width: 54px;
    height: 54px;
  }
  .product-brand .brand-text strong {
    font-size: 1.25rem;
  }
  .product-lockup {
    grid-template-columns: 76px auto;
    gap: 18px;
    margin-bottom: 20px;
  }
  .product-lockup img {
    width: 76px;
    height: 76px;
  }
  .product-lockup strong {
    font-size: 1.8rem;
  }
  .brand-text em { display: none; }
  .nav-list { display: grid; grid-template-columns: repeat(2, 1fr); }
  .nav-item { justify-content: flex-start; padding: 0 11px; font-size: 0.8rem; }
  .top-actions { width: 100%; }
  .primary-action { flex: 1; }
  .detail-meta { grid-template-columns: 1fr; }
  .doc-head { flex-direction: column; }
  .price { text-align: center; }
}

/* ═══════════════════════════════════════════════════════════════════════
   IWHF v2 POLISH LAYER  —  Design Guide v2.0
   Editorial hierarchy + dashboard refinements. Applied to the existing
   class system so layout structure is preserved. Loaded last so its
   declarations override earlier rules where intentional.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Editorial typography rhythm ───────────────────────────────────── */
.personal-section,
.donor-rfps,
.donor-applicants,
.donor-review,
.donor-portfolio,
.donor-intel-section,
.donor-wedge,
.bento-how {
  padding-top: var(--s-7);
  padding-bottom: var(--s-7);
  border-top: 1px solid var(--hairline-soft);
}
.personal-section:first-of-type,
.donor-rfps:first-of-type {
  border-top: 0;
}

.personal-section .section-head,
.donor-rfps .section-head,
.donor-applicants .section-head,
.donor-review .section-head,
.donor-portfolio .section-head,
.donor-intel-section .section-head,
.bento-how .section-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: var(--s-6);
  margin-bottom: var(--s-6);
  padding-bottom: var(--s-4);
  border-bottom: 1px solid var(--hairline);
}
.section-head h2,
.personal-section .section-head h2 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(1.85rem, 2.6vw, 2.55rem);
  line-height: 1.06;
  letter-spacing: -0.018em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.section-head h2 em,
.personal-section .section-head h2 em {
  font-style: italic;
  font-weight: 400;
  color: var(--forest);
}
.section-sub,
.personal-section .section-sub {
  max-width: 68ch;
  color: var(--slate);
  font-family: var(--body);
  font-size: 0.96rem;
  line-height: 1.6;
}

/* eyebrow: monoline + champagne dot (editorial signature) */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--mono);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--champagne-deep);
  margin-bottom: var(--s-3);
}
.eyebrow .rule {
  display: inline-block;
  width: 26px;
  height: 1px;
  background: var(--champagne-deep);
  opacity: 0.7;
}
.section-head .eyebrow {
  margin-bottom: var(--s-3);
}

/* ── KPI / metric cards: refined editorial stat card ──────────────── */
.metric,
.metrics-strip > div,
.tracker-kpis > * {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--elev-1);
  transition: border-color var(--dur-base) var(--ease-standard),
              box-shadow var(--dur-base) var(--ease-standard);
}
.metric:hover,
.tracker-kpis > *:hover {
  border-color: var(--hairline-strong);
  box-shadow: var(--elev-2);
}
.metric .metric-num,
.tracker-kpis b,
.tracker-kpis strong {
  font-family: var(--display);
  font-weight: 400;
  font-size: 2.3rem;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-feature-settings: "tnum" 1, "lnum" 1;
}
.metric p,
.tracker-kpis p,
.tracker-kpis span {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  margin-top: 10px;
}
.metric small {
  font-family: var(--body);
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.82rem;
  color: var(--slate-soft);
  margin-top: 4px;
}
.metric-trend {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  border-radius: var(--r-pill);
  padding: 3px 9px;
}
.metric-trend.up   { color: var(--signal-up);   background: var(--signal-up-soft); }
.metric-trend.down { color: var(--signal-down); background: var(--signal-down-soft); }
.metric-trend.flat { color: var(--slate);       background: var(--hairline-soft); }
.metric-hero {
  background: linear-gradient(135deg, var(--bone) 0%, var(--paper-warm) 100%);
  border: 1px solid var(--hairline-gold);
}
.metric-signal {
  background: var(--forest);
  border-color: var(--forest-deep);
  color: var(--bone);
}
.metric-signal .metric-num { color: var(--bone); }
.metric-signal p { color: rgba(250, 248, 243, 0.74); }

/* ── Buttons: align with design-guide btn taxonomy ────────────────── */
.primary-action,
.ghost-action {
  border-radius: var(--r-pill);
  font-family: var(--sans);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: background var(--dur-fast) var(--ease-standard),
              color var(--dur-fast) var(--ease-standard),
              border-color var(--dur-fast) var(--ease-standard),
              transform var(--dur-fast) var(--ease-standard),
              box-shadow var(--dur-fast) var(--ease-standard);
}
.primary-action {
  background: var(--ink);
  color: var(--bone);
  border: 1px solid var(--ink);
}
.primary-action:hover {
  background: var(--forest);
  border-color: var(--forest);
  color: var(--bone);
  transform: translateY(-1px);
  box-shadow: var(--elev-2);
}
.ghost-action {
  background: var(--surface);
  color: var(--ink);
  border: 1px solid var(--hairline-strong);
}
.ghost-action:hover {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
  transform: translateY(-1px);
}
.primary-action:focus-visible,
.ghost-action:focus-visible {
  outline: none;
  box-shadow: var(--ring);
}

/* ── Personal dashboard polish ────────────────────────────────────── */
.personal-body {
  background: var(--bone);
  background-image:
    radial-gradient(circle at 92% 4%, rgba(161, 132, 74, 0.10), transparent 35%),
    radial-gradient(circle at 4% 96%, rgba(15, 61, 52, 0.08), transparent 38%);
}
.personal-masthead {
  background: rgba(250, 248, 243, 0.92);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--hairline);
  padding: var(--s-4) var(--s-6);
}
.personal-nav a {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  color: var(--slate);
  padding: 6px 10px;
  border-radius: var(--r-sm);
  transition: background var(--dur-fast) var(--ease-standard),
              color var(--dur-fast) var(--ease-standard);
}
.personal-nav a:hover {
  background: rgba(15, 61, 52, 0.06);
  color: var(--forest);
}
.personal-hero {
  padding-top: var(--s-7);
  padding-bottom: var(--s-7);
}
.hero-greeting h1 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.6rem, 5vw, 4.1rem);
  line-height: 1.02;
  letter-spacing: -0.028em;
  color: var(--ink);
  margin-bottom: var(--s-4);
}
.hero-greeting h1 em {
  font-style: italic;
  font-weight: 400;
  color: var(--forest);
}
.hero-greeting .hero-copy {
  font-family: var(--body);
  font-weight: 300;
  font-size: 1.18rem;
  line-height: 1.55;
  color: var(--slate);
  max-width: 60ch;
}
.hero-hotlist {
  background: var(--forest);
  color: var(--bone);
  border-radius: var(--r-lg);
  padding: var(--s-5);
  box-shadow: var(--shadow-card);
  border: 1px solid var(--forest-deep);
}
.hero-hotlist header .hotlist-tag {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--champagne);
}
.hero-hotlist header .hotlist-count {
  font-family: var(--display);
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--bone);
  font-feature-settings: "tnum" 1;
}

/* brand columns: editorial 3-col card system */
.brand-col {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--elev-1);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.brand-col:hover { box-shadow: var(--elev-2); transform: translateY(-1px); }
.brand-col h3 {
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.brand-col-count {
  font-family: var(--mono);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--champagne-deep);
}

/* Studio cards */
.studio-draft {
  background: var(--surface);
  border-radius: var(--r-md);
  border: 1px solid var(--hairline);
  box-shadow: var(--elev-1);
  padding: var(--s-5);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.studio-draft strong {
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.studio-state {
  font-family: var(--mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: var(--r-pill);
  border: 1px solid currentColor;
  display: inline-flex;
  align-items: center;
}
.studio-meta b {
  font-family: var(--display);
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-size: 1.05rem;
  color: var(--ink);
  font-weight: 500;
}
.workflow-pill {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
  border: 1px solid var(--hairline);
  background: var(--paper);
  padding: 3px 9px;
  border-radius: var(--r-pill);
}

/* Wins grid */
.win-card {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-left: 3px solid var(--signal-up);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--elev-1);
}
.t-status.won {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--signal-up);
}

/* ── Donor portal polish ──────────────────────────────────────────── */
.donor-body {
  background: var(--bone);
  background-image:
    radial-gradient(circle at 92% 4%, rgba(161, 132, 74, 0.10), transparent 35%),
    radial-gradient(circle at 4% 96%, rgba(15, 61, 52, 0.08), transparent 38%);
}
.donor-masthead h1,
.donor-masthead .kinetic-h1 {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 1.0;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.donor-masthead h1 em,
.donor-masthead .kinetic-h1 em {
  font-style: italic;
  font-weight: 400;
  color: var(--forest);
}

/* Bento upgrades */
.bento {
  border-radius: var(--r-lg);
  border: 1px solid var(--hairline);
  box-shadow: var(--elev-1);
  background: var(--surface);
  padding: var(--s-6);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.bento:hover { box-shadow: var(--shadow-card); transform: translateY(-2px); }
.bento h3 {
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.55rem;
  letter-spacing: -0.015em;
  line-height: 1.15;
  color: var(--ink);
}
.bento-step {
  font-family: var(--mono);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--champagne-deep);
}
.bento-stat b {
  font-family: var(--display);
  font-feature-settings: "tnum" 1, "lnum" 1;
  font-weight: 400;
  font-size: 1.8rem;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.bento-dark {
  background: var(--forest);
  color: var(--bone);
  border-color: var(--forest-deep);
}

/* RFP cards */
.rfp-card {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--elev-1);
}
.rfp-card h3 {
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--ink);
  margin: var(--s-3) 0 var(--s-2);
}
.rfp-state {
  font-family: var(--mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 4px 9px;
  border-radius: var(--r-pill);
}
.rfp-id {
  font-family: var(--mono);
  font-size: 0.68rem;
  color: var(--slate);
  letter-spacing: 0.08em;
}
.rfp-stage {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}

/* Donor self card (sticky portfolio) */
.donor-self-card {
  background: var(--forest);
  color: var(--bone);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  box-shadow: var(--shadow-card);
}
.donor-self-card h3 {
  font-family: var(--display);
  font-weight: 400;
  font-style: italic;
  font-size: 1.5rem;
  letter-spacing: -0.012em;
  color: var(--bone);
}

/* ── Sidebar polish (donor portal etc.) ───────────────────────────── */
.sidebar {
  border-right: 1px solid var(--hairline);
  background: rgba(250, 248, 243, 0.78);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
}
.nav-item {
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 500;
  letter-spacing: 0.005em;
  color: var(--slate);
  border-radius: var(--r-sm);
  padding: 9px 12px;
  transition: background var(--dur-fast) var(--ease-standard),
              color var(--dur-fast) var(--ease-standard);
}
.nav-item:hover {
  background: rgba(15, 61, 52, 0.05);
  color: var(--forest);
}
.nav-item.active {
  background: var(--forest);
  color: var(--bone);
}

/* ── Tracker / data tables ───────────────────────────────────────── */
.t-link {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--forest);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.t-link:hover { color: var(--forest-deep); text-decoration-thickness: 2px; }
.t-verify {
  font-family: var(--mono);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--champagne-deep);
  padding: 2px 6px;
  border-radius: var(--r-xs);
  background: var(--champagne-soft);
}
.t-priority {
  font-family: var(--mono);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: var(--r-xs);
}
.t-priority.high { color: var(--signal-down); background: var(--signal-down-soft); }
.t-priority.med  { color: var(--signal-watch); background: var(--signal-watch-soft); }
.t-priority.low  { color: var(--signal-up); background: var(--signal-up-soft); }
.t-priority.unk  { color: var(--slate); background: var(--hairline-soft); }
.t-days {
  font-family: var(--mono);
  font-feature-settings: "tnum" 1;
  font-size: 0.84rem;
  color: var(--ink);
}
.t-days.past   { color: var(--signal-down); }
.t-days.today  { color: var(--signal-down); font-weight: 700; }
.t-days.urgent { color: var(--signal-down); font-weight: 700; }
.t-days.soon   { color: var(--signal-watch); }
.t-days.ok     { color: var(--signal-up); }

/* ── Intel + Desk team cards ─────────────────────────────────────── */
.intel-card-personal,
.desk-team-card {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  padding: var(--s-5);
  box-shadow: var(--elev-1);
  transition: box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.intel-card-personal:hover,
.desk-team-card:hover {
  box-shadow: var(--elev-2);
  transform: translateY(-1px);
}
.intel-tag,
.desk-tag {
  font-family: var(--mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--champagne-deep);
}
.intel-date,
.desk-state {
  font-family: var(--mono);
  font-size: 0.66rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--slate);
}

/* ═══════════════════════════════════════════════════════════════════════
   ADMIN DASHBOARDS (catalog, CRM, members)
   Replaces the previously-inline styles in admin-*.html with a global
   tokenised theme. Each admin page only needs to link styles.css.
   ═══════════════════════════════════════════════════════════════════════ */
.admin-body,
body.admin-body {
  min-height: 100vh;
  margin: 0;
  background: var(--bone);
  background-image:
    radial-gradient(circle at 92% 2%, rgba(161, 132, 74, 0.10), transparent 30%),
    radial-gradient(circle at 6% 98%, rgba(15, 61, 52, 0.07), transparent 36%);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.admin-shell {
  max-width: 1420px;
  margin: 0 auto;
  padding: 36px 32px 96px;
}
.admin-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
  padding-bottom: var(--s-5);
  border-bottom: 1px solid var(--hairline);
}
.admin-brand {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  color: var(--ink);
  text-decoration: none;
}
.admin-brand img { width: 44px; height: 44px; object-fit: contain; }
.admin-brand strong {
  display: block;
  font-family: var(--display);
  font-size: 1.55rem;
  font-weight: 500;
  letter-spacing: -0.005em;
  line-height: 1;
}
.admin-brand span span {
  display: block;
  margin-top: 4px;
  font-family: var(--mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--champagne-deep);
}
.admin-nav {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
}
.admin-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  padding: 8px 14px;
  color: var(--ink);
  background: var(--surface);
  text-decoration: none;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.01em;
  transition: background var(--dur-fast) var(--ease-standard),
              color var(--dur-fast) var(--ease-standard),
              border-color var(--dur-fast) var(--ease-standard);
}
.admin-nav a:hover {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
}
.admin-nav a.active {
  background: var(--forest);
  color: var(--bone);
  border-color: var(--forest);
}
.admin-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 420px);
  gap: var(--s-7);
  align-items: end;
  padding: var(--s-8) 0 var(--s-6);
}
.admin-hero h1 {
  margin: 0;
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.6rem, 6vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: -0.028em;
  color: var(--ink);
}
.admin-hero .lede {
  max-width: 68ch;
  margin: var(--s-4) 0 0;
  color: var(--slate);
  font-family: var(--body);
  font-weight: 300;
  font-size: 1.1rem;
  line-height: 1.6;
}
.admin-status {
  border-left: 3px solid var(--champagne-deep);
  padding: 4px 0 4px var(--s-4);
  color: var(--slate);
  font-size: 0.84rem;
  line-height: 1.6;
  font-family: var(--sans);
}
.admin-status b {
  display: block;
  color: var(--forest);
  font-family: var(--mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-bottom: 6px;
  font-weight: 700;
}
.admin-stats {
  display: grid;
  gap: var(--s-3);
  margin: var(--s-2) 0 var(--s-6);
}
.admin-stat {
  border-top: 1px solid var(--hairline-strong);
  padding: var(--s-4) 0 0;
}
.admin-stat b {
  display: block;
  font-family: var(--display);
  font-weight: 400;
  font-size: 2rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  font-feature-settings: "tnum" 1, "lnum" 1;
  line-height: 1;
}
.admin-stat span {
  display: block;
  margin-top: 8px;
  color: var(--slate);
  font-family: var(--mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 500;
}

/* Queue cards (admin-catalog) */
.queue-dashboard {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--s-3);
  margin: 0 0 var(--s-5);
}
.queue-card {
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: var(--surface);
  padding: var(--s-4) var(--s-4) var(--s-5);
  cursor: pointer;
  text-align: left;
  color: var(--ink);
  font-family: var(--sans);
  transition: border-color var(--dur-base) var(--ease-standard),
              box-shadow var(--dur-base) var(--ease-standard),
              transform var(--dur-base) var(--ease-standard);
}
.queue-card:hover {
  border-color: var(--hairline-strong);
  box-shadow: var(--elev-2);
  transform: translateY(-1px);
}
.queue-card b {
  display: block;
  font-family: var(--display);
  font-weight: 400;
  font-size: 1.85rem;
  letter-spacing: -0.018em;
  color: var(--ink);
  line-height: 1;
}
.queue-card span {
  display: block;
  margin-top: 8px;
  color: var(--slate);
  font-family: var(--mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 500;
}
.queue-card.active {
  border-color: var(--hairline-gold);
  background: var(--champagne-mist);
  box-shadow: var(--shadow-gold);
}

/* Layouts */
.catalog-layout,
.crm-layout {
  display: grid;
  grid-template-columns: minmax(600px, 1fr) minmax(380px, 500px);
  gap: var(--s-5);
  align-items: start;
}
.crm-layout { grid-template-columns: minmax(640px, 1fr) minmax(400px, 520px); }

/* Admin tools (filters, search) */
.admin-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  margin: 0 0 var(--s-4);
  flex-wrap: wrap;
}
.admin-tools input,
.admin-tools select,
.editor-field input,
.editor-field select,
.editor-field textarea {
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  background: var(--surface);
  padding: 11px var(--s-3);
  font-family: var(--sans);
  font-size: 0.86rem;
  font-weight: 500;
  color: var(--ink);
  box-sizing: border-box;
  transition: border-color var(--dur-fast) var(--ease-standard),
              box-shadow var(--dur-fast) var(--ease-standard);
}
.admin-tools input:focus,
.admin-tools select:focus,
.editor-field input:focus,
.editor-field select:focus,
.editor-field textarea:focus {
  outline: none;
  border-color: var(--forest);
  box-shadow: var(--ring);
}
.admin-tools input { min-width: min(360px, 100%); flex: 1; }

/* Bulk action bar */
.bulk-bar {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  flex-wrap: wrap;
  margin: 0 0 var(--s-4);
  padding: var(--s-3) var(--s-4);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: var(--paper-warm);
}
.bulk-bar strong {
  margin-right: auto;
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--forest);
  font-weight: 700;
}
.bulk-bar input {
  min-width: 170px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: var(--surface);
  padding: 9px var(--s-3);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.78rem;
}
.bulk-bar button {
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-pill);
  background: var(--surface);
  color: var(--ink);
  padding: 9px var(--s-3);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.74rem;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background var(--dur-fast) var(--ease-standard),
              color var(--dur-fast) var(--ease-standard),
              border-color var(--dur-fast) var(--ease-standard);
}
.bulk-bar button:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.bulk-bar button.primary { background: var(--forest); color: var(--bone); border-color: var(--forest); }
.bulk-bar button.primary:hover { background: var(--forest-deep); border-color: var(--forest-deep); }
.bulk-bar button.danger { background: var(--signal-down); color: var(--bone); border-color: var(--signal-down); }
.bulk-bar button.danger:hover { background: #8a3329; border-color: #8a3329; }
.bulk-bar button:disabled { opacity: 0.4; cursor: not-allowed; }

/* Admin data tables */
.admin-table-wrap,
.editor-panel {
  background: var(--surface);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--elev-2);
}
.admin-table-scroll { max-height: 760px; overflow: auto; }
.admin-table-wrap table { width: 100%; border-collapse: collapse; min-width: 1080px; }
.admin-table-wrap th,
.admin-table-wrap td {
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--hairline-soft);
  text-align: left;
  vertical-align: top;
  font-family: var(--sans);
}
.admin-table-wrap th {
  position: sticky;
  top: 0;
  background: var(--paper);
  color: var(--slate);
  font-family: var(--mono);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
  z-index: 1;
  border-bottom: 1px solid var(--hairline);
}
.admin-table-wrap td {
  font-size: 0.84rem;
  line-height: 1.45;
  color: var(--ink);
}
.admin-table-wrap tbody tr:last-child td { border-bottom: 0; }
.admin-table-wrap tbody tr:hover { background: var(--paper-warm); }
.admin-table-wrap tr[data-id],
.admin-table-wrap tr[data-funder-id] { cursor: pointer; }
.admin-table-wrap tr.selected {
  background: var(--champagne-mist);
  box-shadow: inset 3px 0 0 var(--champagne-deep);
}
.admin-table-wrap td small {
  display: block;
  margin-top: 4px;
  color: var(--slate);
  font-family: var(--mono);
  font-size: 0.7rem;
  word-break: break-word;
}
.select-cell { width: 36px; }
.select-cell input { width: 16px; height: 16px; accent-color: var(--forest); }

/* Pills / status chips (admin) */
.pill {
  display: inline-flex;
  align-items: center;
  border-radius: var(--r-pill);
  padding: 4px 10px;
  font-family: var(--mono);
  font-size: 0.62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.pill.seeded { background: var(--champagne-soft); color: var(--champagne-deep); }
.pill.verified { background: var(--signal-up-soft); color: var(--signal-up); }
.pill.needs_review { background: var(--signal-down-soft); color: var(--signal-down); }
.pill.archived { background: var(--hairline-soft); color: var(--slate); }
.pill.target,
.pill.researching { background: var(--champagne-soft); color: var(--champagne-deep); }
.pill.warm_intro,
.pill.contacted,
.pill.meeting { background: var(--signal-info-soft); color: var(--signal-info); }
.pill.proposal,
.pill.committed,
.pill.partner { background: var(--signal-up-soft); color: var(--signal-up); }
.pill.deprioritized { background: var(--hairline-soft); color: var(--slate); }
.pill.active { background: var(--signal-up-soft); color: var(--signal-up); }
.pill.pending { background: var(--champagne-soft); color: var(--champagne-deep); }
.pill.suspended { background: var(--signal-down-soft); color: var(--signal-down); }

/* Queue chips */
.queue-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.queue-chip {
  display: inline-flex;
  align-items: center;
  border-radius: var(--r-pill);
  padding: 3px 9px;
  background: var(--hairline-soft);
  color: var(--forest);
  font-family: var(--mono);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.queue-chip.warn { background: var(--champagne-soft); color: var(--champagne-deep); }
.queue-chip.hot  { background: var(--signal-down-soft); color: var(--signal-down); }
.queue-chip.quiet { background: var(--hairline-soft); color: var(--slate); }

/* Priority indicator */
.priority {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--slate);
  font-family: var(--mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-weight: 700;
}
.priority i {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--champagne-deep);
}
.priority.high i,
.priority.critical i { background: var(--signal-down); }

.source-link {
  color: var(--forest);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}
.source-link:hover { color: var(--forest-deep); text-decoration-thickness: 2px; }

/* Queue / insight panels */
.queue-panel,
.insight-panel {
  margin: 0 0 var(--s-4);
  padding: var(--s-4);
  border: 1px solid var(--hairline);
  border-radius: var(--r-md);
  background: var(--paper-warm);
}
.queue-panel h3,
.insight-panel h3 {
  margin: 0 0 var(--s-2);
  font-family: var(--display);
  font-weight: 500;
  font-size: 1rem;
  letter-spacing: -0.005em;
  color: var(--forest);
}
.queue-panel p,
.insight-panel p {
  margin: 0;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.82rem;
  line-height: 1.55;
}

/* Audit / interaction log */
.audit-trail,
.interaction-log {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--hairline);
}
.audit-trail h3,
.interaction-log h3 {
  margin: 0 0 var(--s-3);
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--ink);
}
.audit-list,
.interaction-list {
  display: grid;
  gap: var(--s-2);
  max-height: 280px;
  overflow: auto;
  padding-right: 4px;
}
.audit-event,
.interaction {
  border: 1px solid var(--hairline);
  border-radius: var(--r-sm);
  background: var(--paper-warm);
  padding: var(--s-3);
}
.audit-event strong,
.interaction strong {
  display: block;
  font-family: var(--mono);
  color: var(--forest);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.audit-event span,
.interaction span {
  display: block;
  margin-top: 4px;
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.8rem;
  line-height: 1.5;
}

/* Editor panel (sidebar) */
.editor-panel { position: sticky; top: 18px; padding: var(--s-5); }
.editor-empty { padding: var(--s-5); color: var(--slate); line-height: 1.6; font-family: var(--sans); }
.editor-title {
  margin: 0 0 var(--s-3);
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.8rem;
  letter-spacing: -0.012em;
  line-height: 1.1;
  color: var(--ink);
}
.editor-sub {
  margin: calc(var(--s-2) * -1) 0 var(--s-4);
  color: var(--slate);
  line-height: 1.55;
  font-family: var(--body);
  font-size: 0.92rem;
}
.editor-form { display: grid; gap: var(--s-3); }
.editor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-3); }
.editor-field label {
  display: block;
  margin: 0 0 6px;
  color: var(--champagne-deep);
  font-family: var(--mono);
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
}
.editor-field input,
.editor-field select,
.editor-field textarea { width: 100%; }
.editor-field textarea { min-height: 92px; resize: vertical; line-height: 1.5; }
.editor-actions { display: flex; gap: var(--s-2); flex-wrap: wrap; margin-top: 6px; }

/* Source register */
.source-register {
  margin-top: var(--s-5);
  padding-top: var(--s-4);
  border-top: 1px solid var(--hairline);
}
.source-register h3 {
  margin: 0 0 6px;
  font-family: var(--display);
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--ink);
}
.source-register p {
  margin: 0 0 var(--s-3);
  color: var(--slate);
  font-family: var(--sans);
  font-size: 0.82rem;
  line-height: 1.55;
}

/* Admin action buttons */
.save-btn,
.danger-btn,
.ghost-btn {
  border: 0;
  border-radius: var(--r-pill);
  padding: 11px var(--s-4);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background var(--dur-fast) var(--ease-standard),
              transform var(--dur-fast) var(--ease-standard),
              box-shadow var(--dur-fast) var(--ease-standard);
}
.save-btn { background: var(--forest); color: var(--bone); }
.save-btn:hover { background: var(--forest-deep); transform: translateY(-1px); box-shadow: var(--elev-2); }
.danger-btn { background: var(--ink); color: var(--bone); }
.danger-btn:hover { background: var(--signal-down); transform: translateY(-1px); box-shadow: var(--elev-2); }
.ghost-btn { border: 1px solid var(--hairline-strong); background: var(--surface); color: var(--ink); }
.ghost-btn:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.save-btn:disabled,
.danger-btn:disabled,
.ghost-btn:disabled { opacity: 0.45; cursor: wait; }

.empty { padding: var(--s-6); color: var(--slate); font-family: var(--sans); }

/* Admin select inside table cells */
.admin-table-wrap td select {
  width: 100%;
  min-width: 122px;
  border: 1px solid var(--hairline-strong);
  border-radius: var(--r-sm);
  background: var(--surface);
  padding: 8px 10px;
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.78rem;
  color: var(--ink);
}

/* Stat grids — column variants set inline per page via classes */
.admin-stats.cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.admin-stats.cols-6 { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.admin-stats.cols-8 { grid-template-columns: repeat(8, minmax(0, 1fr)); }

@media (max-width: 1060px) {
  .catalog-layout, .crm-layout { display: block; }
  .editor-panel { position: static; margin-top: var(--s-4); }
  .admin-stats.cols-6,
  .admin-stats.cols-8 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .queue-dashboard { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 780px) {
  .admin-shell { padding: 28px 18px 72px; }
  .admin-top, .admin-hero, .admin-tools { display: block; }
  .admin-nav { margin-top: var(--s-4); }
  .admin-stats.cols-4,
  .admin-stats.cols-6,
  .admin-stats.cols-8 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .admin-tools input,
  .admin-tools select { width: 100%; margin-bottom: 10px; }
  .editor-grid { grid-template-columns: 1fr; }
}
