/* ============================================================
   CFO Babies — home (hub) page
   ============================================================ */

/* ─── Hero ─── */
.hero {
  padding-block: var(--space-12) var(--space-16);
  margin: 0 auto;
  text-align: left;
  position: relative;
}

.hero-kicker {
  display: inline-block;
  margin-bottom: var(--space-5);
  padding: 3px 12px;
  border: 1px solid transparent;
  background: var(--color-babies);
  color: #fff;
  border-radius: var(--radius-full, 999px);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.6rem + 5vw, 5rem);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-6);
  max-width: 16ch;
  text-wrap: balance;
}
.hero-title em {
  font-style: italic;
  color: var(--color-text);
  background: linear-gradient(transparent 62%, var(--color-babies-soft) 62%);
  padding: 0 0.05em;
}

.hero-deck {
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--color-text);
  max-width: 52ch;
  margin-bottom: var(--space-8);
}

.hero-cta {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}
.hero-cta .btn { padding: var(--space-4) var(--space-6); font-size: var(--text-base); }
.hero-cta .btn-primary {
  background: var(--color-babies);
  color: #fff;
  border-color: transparent;
}
.hero-cta .btn-primary:hover {
  background: var(--color-babies-hover);
  transform: translateY(-2px) rotate(-0.5deg);
  box-shadow: var(--shadow-md);
}

.hero-meta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  gap: var(--space-2);
}
.hero-meta #hero-issue { white-space: nowrap; }
.hero-meta .dot {
  width: 8px; height: 8px;
  background: var(--color-babies);
  border-radius: 50%;
  display: inline-block;
  box-shadow: 0 0 0 4px rgba(211, 54, 131, 0.15);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(211, 54, 131, 0.15); }
  50%      { box-shadow: 0 0 0 6px rgba(211, 54, 131, 0.04); }
}

/* Desktop two-column hero: text left, collage floats right.
   (Base + tilt rules for .hero-collage live in home-fun.css) */
@media (min-width: 980px) {
  .hero { max-width: 1120px; padding-right: 420px; }
  .hero-collage {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 380px;
    max-width: none;
    margin: 0;
  }
}

/* ─── Section scaffolding ─── */
.section-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-2xl);
  margin-bottom: var(--space-3);
  letter-spacing: -0.01em;
}
.section-deck {
  color: var(--color-text-muted);
  max-width: 60ch;
  margin-bottom: var(--space-8);
  font-size: var(--text-base);
}

.home > section { margin-bottom: var(--space-16); }

/* ─── Three-register strip ─── */
.register-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.register-card {
  padding: var(--space-6);
  border-radius: var(--radius-lg);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  position: relative;
  overflow: hidden;
  transition: transform var(--transition);
}
.register-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: var(--register-accent, var(--color-primary));
}
.register-card:hover { transform: translateY(-2px); }

.register-babies { --register-accent: var(--color-babies); }
.register-cfo    { --register-accent: var(--color-brand-teal); }
.register-cogito { --register-accent: var(--color-cogito); }

.register-handle {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--register-accent);
  letter-spacing: 0.04em;
}
.register-name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--color-text);
  margin-bottom: 0;
}
.register-babies .register-name {
  font-family: var(--font-babies-display);
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  font-size: 1.5rem;
}
.register-blurb {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.55;
}
.register-tag {
  margin-top: auto;
  padding-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  border-top: 1px dashed var(--color-divider);
}

/* ─── Franchise grid ─── */
.franchise-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
}
.franchise-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  color: var(--color-text);
  position: relative;
  overflow: hidden;
  min-height: 240px;
  text-decoration: none;
  border-bottom: 1px solid var(--color-border);
  transition: transform var(--transition), border-color var(--transition), background var(--transition);
}
.franchise-card:hover {
  transform: translateY(-2px);
  background: var(--color-surface-2);
  border-color: var(--color-text);
  color: var(--color-text);
}

.franchise-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}
.franchise-num {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.16em;
  color: var(--color-text-faint);
}
.franchise-status {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-surface-offset);
  color: var(--color-text-muted);
}
.franchise-live .franchise-status {
  background: var(--color-babies);
  color: white;
}
.franchise-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--color-text);
  line-height: 1.1;
  margin-bottom: 0;
}
.franchise-format {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.franchise-example {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-text);
  opacity: 0.85;
  flex: 1;
}
.franchise-cta {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-primary);
  margin-top: auto;
}

.franchise-soon { opacity: 0.78; }
.franchise-soon .franchise-cta { color: var(--color-text-muted); }
.franchise-soon:hover { opacity: 1; }

/* Babies card on hub uses condensed display */
.franchise-card.franchise-babies .franchise-title {
  font-family: var(--font-babies-display);
  font-style: normal;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  font-size: 1.4rem;
  line-height: 1.05;
}
.franchise-card.franchise-babies .franchise-cta { color: var(--color-babies); }
.franchise-card.franchise-babies .franchise-status { background: var(--color-babies); }

/* Manifesto card */
.franchise-manifesto {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  background:
    linear-gradient(180deg, var(--color-surface-offset), var(--color-surface));
  border-style: dashed;
  border-color: var(--color-brand-teal);
  color: var(--color-text);
}
.manifesto-kicker {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-brand-teal);
  margin-bottom: var(--space-3);
}
.manifesto-line {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-lg);
  color: var(--color-text);
  line-height: 1.25;
}
.manifesto-sub { color: var(--color-text-muted); font-size: var(--text-base); margin-top: var(--space-2); }
.manifesto-foot {
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-text-muted);
}

/* ─── About ─── */
.about-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-2xl);
  margin-block: var(--space-3) var(--space-6);
}
.about-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--space-10);
  padding-block: var(--space-6);
  border-top: 1px solid var(--color-divider);
  border-bottom: 1px solid var(--color-divider);
}
.about-grid p {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text);
  max-width: 60ch;
}
.about-list { list-style: none; display: flex; flex-direction: column; gap: var(--space-3); }
.about-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text);
}
.about-list .label-mono { color: var(--color-text-muted); }

/* ─── Mobile ─── */
@media (max-width: 880px) {
  .register-strip { grid-template-columns: 1fr; }
  .franchise-grid { grid-template-columns: 1fr 1fr; }
  .about-grid { grid-template-columns: 1fr; gap: var(--space-6); }
}
@media (max-width: 560px) {
  .franchise-grid { grid-template-columns: 1fr; }
  .hero-cta { flex-direction: column; align-items: stretch; }
  .hero-cta .btn { justify-content: center; }
}

/* ============================================================
   CFO Interactive — Featured community panel (replaces 3-card strip)
   ============================================================ */
.cfo-feature {
  display: grid;
  grid-template-columns: minmax(240px, 0.85fr) 1.15fr;
  gap: var(--space-8);
  align-items: stretch;
  padding: var(--space-8);
  border-radius: var(--radius-xl, 1rem);
  background:
    radial-gradient(120% 140% at 0% 0%,
      color-mix(in oklab, var(--color-cfo-blue) 10%, var(--color-surface)) 0%,
      var(--color-surface) 55%);
  border: 1px solid var(--color-border);
  position: relative;
  overflow: hidden;
  box-shadow:
    0 1px 2px rgba(20, 30, 30, 0.05),
    0 18px 46px rgba(20, 30, 30, 0.07);
}
.cfo-feature::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, var(--color-cfo-blue), color-mix(in oklab, var(--color-cfo-blue) 40%, #7a7974));
}

.cfo-feature-media {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--color-surface-2, #fbfbf9);
  border: 1px solid var(--color-divider);
  display: grid;
  place-items: center;
  min-height: 260px;
}
/* .cfo-feature-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 600ms cubic-bezier(0.16, 1, 0.3, 1);
} */
 .cfo-feature-media {
  background: var(--color-surface-offset);   /* matches the PNG's cream tone */
  border-radius: var(--radius-lg);
  padding: clamp(16px, 3vw, 32px);            /* even breathing room, all sides */
  display: grid;
  place-items: center;
  min-height: 260px;
}

.cfo-feature-media img {
  width: 100%;
  height: auto;
  max-height: 100%;
  object-fit: contain;   /* no crop, no zoom-in on the bust */
  border-radius: var(--radius-md);
  display: block;
}
background: radial-gradient(120% 120% at 30% 20%, var(--color-surface-2), var(--color-surface-offset));
.cfo-feature:hover .cfo-feature-media img { transform: scale(1.03); }

.cfo-feature-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-block: var(--space-2);
}
.cfo-feature-handle {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  color: var(--color-cfo-blue);
  margin: 0;
}
.cfo-feature-name {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(2rem, 1.4rem + 2.4vw, 3rem);
  line-height: 1.02;
  letter-spacing: -0.01em;
  color: var(--color-text);
  margin: 0;
}
.cfo-feature-blurb {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: 1.6;
  max-width: 56ch;
  margin: 0;
}
.cfo-feature-points {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-6);
  margin: var(--space-2) 0 0;
  padding: 0;
  list-style: none;
}
.cfo-feature-points li {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.cfo-feature-points .pt-k {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-text-faint);
  margin-bottom: 2px;
}
.cfo-feature-cta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-3);
}
.btn-cfo {
  display: inline-block;
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-full, 999px);
  background: var(--color-cfo-blue);
  color: #fff;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: transform 180ms cubic-bezier(0.16,1,0.3,1), background 180ms;
}
.btn-cfo:hover { transform: translateY(-2px); background: color-mix(in oklab, var(--color-cfo-blue) 85%, #000); }
.cfo-feature-link {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-decoration: none;
}
.cfo-feature-link:hover { color: var(--color-cfo-blue); }
.cfo-feature-tag {
  margin-top: auto;
  padding-top: var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-text-faint);
  border-top: 1px dashed var(--color-divider);
}

@media (max-width: 720px) {
  .cfo-feature {
    grid-template-columns: 1fr;
    gap: var(--space-6);
    padding: var(--space-5);
  }
  .cfo-feature-media { min-height: 200px; }
}



/* ============================================================
   MIGRATED FROM INLINE — structural sections (home only)
   ============================================================ */

/* ─── Two-register override (Babies + CFO Interactive) ─── */
.register-strip { grid-template-columns: repeat(2, 1fr); gap: var(--space-5); }
.register-cfo   { --register-accent: var(--color-cfo-blue); }
.register-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-sm); }

/* ─── CFO feature panel — remaining parts ─── */
.cfo-feature-points {
  list-style: none; display: flex; flex-wrap: wrap;
  gap: var(--space-6); margin-bottom: var(--space-6);
}
.cfo-feature-points li { font-size: var(--text-sm); color: var(--color-text); }
.cfo-feature-points .pt-k {
  display: block; font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-text-faint); margin-bottom: 2px;
}
.cfo-feature-actions { display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap; }
.cfo-feature-follow {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-cfo-blue);
}
.cfo-feature-follow:hover { filter: brightness(1.15); }
.cfo-feature-tag {
  margin-top: var(--space-5); font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-text-faint);
}

/* ─── Section gutters / wrap (home) ─── */
.page.home > section:not(.hero):not(.toxic) { padding-block: clamp(var(--space-10), 4vw, var(--space-16)); }
.page.home > section.hero { padding-block: clamp(var(--space-10), 5vw, var(--space-16)) clamp(var(--space-12), 6vw, var(--space-20)); }
.home > .wrap { max-width: 1080px; margin-inline: auto; padding-inline: clamp(var(--space-5), 4vw, var(--space-10)); }
.fun-band .wrap { max-width: 1080px; margin-inline: auto; padding-inline: clamp(var(--space-5), 4vw, var(--space-10)); padding-block: clamp(var(--space-10), 5vw, var(--space-16)); }
#cfo-interactive { padding-bottom: clamp(var(--space-6), 3vw, var(--space-10)); }
#cfo-interactive > .cfo-feature { margin-block: 0; }

/* ─── SATIRE: CFO bonus band ─── */
.bonus-band {
  margin-block: var(--space-12); padding-block: var(--space-16);
  border-block: 1px solid var(--color-divider);
  background:
    radial-gradient(120% 90% at 50% 0%, color-mix(in oklab, var(--color-babies) 8%, transparent), transparent 60%),
    var(--color-surface-offset);
  text-align: center; overflow: hidden;
}
.bonus-inner { max-width: 660px; margin: 0 auto; padding-inline: var(--space-4); }
.bonus-kicker {
  font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--color-text-muted); margin-bottom: var(--space-4);
}
.bonus-headline {
  font-family: var(--font-display); font-size: clamp(1.9rem, 1.2rem + 3vw, 3.2rem);
  line-height: 1.08; letter-spacing: -0.02em; margin-bottom: var(--space-3); text-wrap: balance;
}
.bonus-figure {
  color: var(--color-babies); font-style: italic; display: inline-block;
  min-width: 2.2ch; text-align: right; font-variant-numeric: tabular-nums;
}
.bonus-sub { font-size: var(--text-lg); color: var(--color-text-muted); margin-bottom: var(--space-6); }
.bonus-sub em { font-style: italic; color: var(--color-text); }
.bonus-btn { font-size: var(--text-base); padding: var(--space-4) var(--space-6); }

/* ─── Toxic CFO section ─── */
.toxic-grid {
  display: grid; grid-template-columns: minmax(240px, 340px) 1fr;
  gap: clamp(var(--space-6), 4vw, var(--space-12)); align-items: center;
}
.toxic-portrait {
  position: relative; border-radius: var(--radius-xl); overflow: hidden;
  border: 1px solid var(--color-border); box-shadow: var(--shadow-md); background: var(--color-surface-offset);
}
.toxic-portrait img { width: 100%; height: auto; display: block; }
.toxic-portrait-cap {
  padding: var(--space-3) var(--space-4); font-family: var(--font-mono); font-size: var(--text-xs);
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--color-text-muted);
  background: var(--color-surface-2); border-top: 1px solid var(--color-border);
}
.toxic-kicker {
  font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--color-babies);
}
.toxic-name { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--color-text); margin-block: var(--space-2) var(--space-4); }
.toxic-bio { color: var(--color-text-muted); max-width: 60ch; }
.toxic-quote {
  margin-block: var(--space-6); padding: var(--space-5) var(--space-6);
  background: var(--color-surface-2); border-left: 3px solid var(--color-babies); border-radius: var(--radius-md);
}
.toxic-quote-label { display: block; font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-text-faint); margin-bottom: var(--space-2); }
.toxic-quote blockquote { font-family: var(--font-display); font-size: var(--text-lg); color: var(--color-text); font-style: italic; }
#toxic-daily { transition: opacity 160ms ease; }
.toxic-verdict-btn {
  margin-top: var(--space-3); font-family: var(--font-mono); font-size: var(--text-xs);
  text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-babies);
  background: none; border: none; padding: 0; cursor: pointer;
}
.toxic-verdict-btn:hover { filter: brightness(1.15); transform: translateX(2px); }
.toxic-tease { margin-top: var(--space-5); margin-bottom: var(--space-8); font-style: italic; color: var(--color-text-muted); }
.toxic-tease::before { content: "↓ "; color: var(--color-babies); font-style: normal; }
.toxic-lines { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-6); }
.toxic-lines li { color: var(--color-text-muted); font-style: italic; padding-left: var(--space-4); border-left: 2px solid var(--color-divider); }
.toxic-actions { display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap; }
.toxic-follow { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-babies); }
.toxic-follow:hover { filter: brightness(1.1); }
@media (max-width: 780px) { .toxic-grid { grid-template-columns: 1fr; } .toxic-portrait { max-width: 320px; margin-inline: auto; } }

/* ─── One building, two doors ─── */
.doors { margin-top: var(--space-8); display: grid; grid-template-columns: 1fr auto 1fr; align-items: stretch; gap: var(--space-5); }
.door { display: flex; flex-direction: column; gap: var(--space-2); padding: var(--space-8); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-xl); box-shadow: var(--shadow-sm); }
.door-cfo { background: var(--color-surface-2); border-color: var(--color-cfo-blue); }
.door-num { font-family: var(--font-mono); font-size: var(--text-2xl); color: var(--color-text-faint); line-height: 1; }
.door-handle { display: flex; align-items: center; gap: var(--space-2); font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-babies); }
.door-handle-cfo { color: var(--color-cfo-blue); }
.door .cat-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-babies); display: inline-block; }
.door .cat-dot-cfo { background: var(--color-cfo-blue); }
.door-name { font-family: var(--font-display); font-size: var(--text-xl); color: var(--color-text); margin-top: var(--space-1); }
.door-blurb { color: var(--color-text-muted); }
.door-tag { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-faint); margin-top: auto; padding-top: var(--space-3); }
.door-link { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: var(--space-2); padding-inline: var(--space-2); }
.door-link-line { flex: 1; width: 2px; background: linear-gradient(var(--color-babies), var(--color-cfo-blue)); min-height: 24px; }
.door-link-label { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--color-text-muted); white-space: nowrap; writing-mode: vertical-rl; transform: rotate(180deg); }
@media (max-width: 780px) {
  .doors { grid-template-columns: 1fr; }
  .door-link { flex-direction: row; }
  .door-link-line { width: auto; height: 2px; min-height: 0; min-width: 24px; background: linear-gradient(90deg, var(--color-babies), var(--color-cfo-blue)); }
  .door-link-label { writing-mode: horizontal-tb; transform: none; }
}

/* ─── CFO CTA button (dark blue) ─── */
.btn-cfo { background: var(--color-cfo-blue); color: #fff; border-color: var(--color-cfo-blue); }
.btn-cfo:hover { background: #16264f; color: #fff; transform: translateY(-1px); box-shadow: var(--shadow-md); }

