/* ═══════════════════════════════════════════════════════════════════════
   Bonaparte & Leggatt — Design B (Concourse / split-flap board)
   Slot: b  |  All selectors scoped [data-design="b"].dq-design
   Motion gate: ONLY transform / opacity / clip-path animated
   Hover transforms: ALL inside @media (hover:hover) and (pointer:fine)
   ═══════════════════════════════════════════════════════════════════════ */

/* ── Token block ─────────────────────────────────────────────────────── */
[data-design="b"] {
  --design-b-primary: #D99A33;

  /* Color — light / day */
  --hall: #E7EAEC;
  --board: #15212C;
  --tile: #F1ECE0;
  --well: #DBDFE2;
  --ink: #16212B;
  --ink-2: #39454F;
  --muted: #5B6770;
  --on-board: #F1ECE0;
  --on-board-2: #A7B6C0;
  --rule: #CBD0D4;
  --rule-2: #A8B0B6;
  --signal: #D99A33;
  --signal-2: #F0C067;
  --secondary: #15212C;
  --critical: #BD443A;
  --success: #3E945F;

  /* Board grammar */
  --sheen: color-mix(in oklab, #ffffff, transparent 22%);
  --tile-hinge: color-mix(in oklab, #0A1218, transparent 74%);
  --board-shadow: inset 0 1px 0 var(--sheen), 0 30px 60px -42px color-mix(in oklab,#000, transparent 35%), 0 0 0 1px color-mix(in oklab,#000, transparent 60%);
  --board-recess: inset 0 2px 5px color-mix(in oklab,#000, transparent 55%), inset 0 0 0 1px var(--rule);
  --tile-raise: inset 0 1px 0 var(--sheen), 0 6px 14px -10px color-mix(in oklab,#000, transparent 50%);

  /* Type */
  --face-board: "Söhne","Suisse Int'l","Neue Haas Grotesk Display","GT America","Inter",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --face-text: "Frutiger","Seravek","Avenir Next","Söhne",-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --face-mono: "GT America Mono","IBM Plex Mono","Fragment Mono",ui-monospace,"SFMono-Regular","Courier New",monospace;
  --type-display: clamp(2.25rem, 8vw, 4.5rem);
  --type-headline: clamp(1.5rem, 4.5vw, 2.5rem);
  --type-title: clamp(1.125rem, 2vw, 1.375rem);
  --type-lead: clamp(1.0625rem, 1.6vw, 1.25rem);
  --type-body: 1.0625rem;
  --type-caption: 0.875rem;
  --type-kicker: 0.75rem;
  --lh-display: 1.05;
  --lh-head: 1.1;
  --lh-lead: 1.55;
  --lh-body: 1.65;
  --tr-board: -0.01em;
  --tr-kicker: 0.22em;

  /* Spacing (4px base) */
  --flap: 4px;
  --hinge-gap: 8px;
  --tile-pad: 12px;
  --unit: 16px;
  --col: 24px;
  --gutter: 32px;
  --margin: 48px;
  --platform: 64px;
  --hall-gap: 96px;
  --terminal: 128px;
  --reading: 66ch;
  --col-max: 760px;
  --col-wide: 960px;

  /* Motion */
  --ease-seat: cubic-bezier(0.2, 0.9, 0.1, 1);
  --ease-roll: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-track: cubic-bezier(0.65, 0, 0.35, 1);
  --t-flap: 480ms;
  --t-seat: 380ms;
  --t-tick: 160ms;
  --t-quick: 200ms;

  /* Radius */
  --r-tile: 3px;
  --r-board: 6px;
  --r-cut: 4px;
  --r-pip: 999px;
  --r-well: 4px;
}

@media (prefers-color-scheme: dark) {
  [data-design="b"] {
    --hall: #0D161D;
    --board: #0A1218;
    --tile: #ECE6D9;
    --well: #070E14;
    --ink: #ECEFF2;
    --ink-2: #C3CCD2;
    --muted: #8B98A1;
    --on-board: #F1ECE0;
    --on-board-2: #A7B6C0;
    --rule: #233039;
    --rule-2: #34444E;
    --signal: #EDB152;
    --signal-2: #F6D089;
    --secondary: #0A1218;
    --critical: #FF7A70;
    --success: #74C795;
    --sheen: color-mix(in oklab, #ffffff, transparent 86%);
    --tile-hinge: color-mix(in oklab, #000000, transparent 58%);
  }
}

/* ── Overflow / mobile containment ──────────────────────────────────── */
[data-design="b"].dq-design,
[data-design="b"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="b"].dq-design * { min-width: 0; }
[data-design="b"].dq-design img,
[data-design="b"].dq-design svg:not([data-keep-size]) { max-width: 100%; height: auto; }

/* ── Base ────────────────────────────────────────────────────────────── */
[data-design="b"] {
  font-family: var(--face-text);
  font-size: var(--type-body);
  line-height: var(--lh-body);
  background: var(--hall);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 1 — Animated minimalist header
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-header {
  position: sticky;
  top: 0;
  z-index: 40;
  box-sizing: border-box;
  background: color-mix(in oklab, var(--hall), transparent 10%);
  backdrop-filter: saturate(1.05) blur(8px);
  border-bottom: 1px solid var(--rule);
}
[data-design="b"] .cn-header__bar {
  max-width: var(--col-wide);
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--unit);
  padding: var(--unit) var(--col);
}
[data-design="b"] .cn-wordmark {
  font-family: var(--face-board);
  font-weight: 650;
  font-size: clamp(1.125rem, 3vw, 1.5rem);
  color: var(--ink);
  text-decoration: none;
  letter-spacing: var(--tr-board);
  perspective: 600px;
  display: inline-flex;
}
[data-design="b"] .cn-wordmark .cn-char {
  display: inline-block;
  white-space: pre;
  transform-origin: center top;
  animation: b-flap var(--t-flap) var(--ease-seat) calc(120ms + var(--i) * 34ms) both;
}
/* Atmospheric standby track — the one header animation layer */
[data-design="b"] .cn-header__standby {
  position: absolute;
  inset: auto 0 -1px 0;
  height: 2px;
  pointer-events: none;
  opacity: .85;
  background:
    linear-gradient(90deg, transparent, var(--signal) 50%, transparent) no-repeat,
    repeating-linear-gradient(90deg, var(--rule) 0 1px, transparent 1px 7px);
  background-size: 38% 100%, 100% 100%;
  animation: b-standby-pan 28s linear infinite;
}
[data-design="b"] .cn-burger {
  width: 48px;
  height: 48px;
  display: grid;
  place-content: center;
  gap: 5px;
  background: none;
  border: 0;
  cursor: pointer;
}
[data-design="b"] .cn-burger span {
  display: block;
  width: 24px;
  height: 1.5px;
  background: var(--ink);
  transition: transform var(--t-quick) var(--ease-seat), opacity var(--t-quick) var(--ease-seat);
}
[data-design="b"] .cn-burger[aria-expanded="true"] span:first-child {
  transform: translateY(3.25px) rotate(45deg);
}
[data-design="b"] .cn-burger[aria-expanded="true"] span:last-child {
  transform: translateY(-3.25px) rotate(-45deg);
}
/* Index drawer — hidden until open.
   [hidden] must beat the display:flex rule; use !important per contract guard
   ("don't let a base display rule override the hidden attr"). */
[data-design="b"] .cn-index[hidden] { display: none !important; }
[data-design="b"] .cn-index {
  position: fixed;
  inset: 0;
  z-index: 60;
  background: var(--hall);
  box-sizing: border-box;
  padding: var(--hall-gap) var(--col) var(--margin);
  display: flex;
  flex-direction: column;
  gap: var(--gutter);
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity var(--t-flap) var(--ease-roll), transform var(--t-flap) var(--ease-roll);
}
[data-design="b"] .cn-index[data-open] { opacity: 1; transform: none; }
[data-design="b"] .cn-index__close {
  align-self: flex-end;
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  background: none;
  border: 0;
  color: var(--muted);
  cursor: pointer;
}
[data-design="b"] .cn-index__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--unit);
  counter-reset: idx;
}
[data-design="b"] .cn-index__list a {
  font-family: var(--face-board);
  font-weight: 650;
  font-size: clamp(1.5rem, 6vw, 2.5rem);
  color: var(--ink);
  text-decoration: none;
  letter-spacing: var(--tr-board);
  display: flex;
  align-items: baseline;
  gap: var(--unit);
}
[data-design="b"] .cn-index__list a::before {
  counter-increment: idx;
  content: "No." counter(idx, decimal-leading-zero);
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .1em;
  color: var(--muted);
}
[data-design="b"] .cn-drawer-cta {
  align-self: flex-start;
  margin-top: var(--unit);
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 3 — Hero (dark board, standby track, 3 text elements)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-hero {
  position: relative;
  box-sizing: border-box;
  overflow: clip;
  background: var(--board);
  box-shadow: var(--board-shadow);
  padding: var(--terminal) var(--col) var(--hall-gap);
}
/* Board field backdrop — visual only, no copy */
[data-design="b"] .cn-hero__field {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: clip;
  opacity: .55;
  background:
    repeating-linear-gradient(0deg, color-mix(in oklab, var(--on-board), transparent 92%) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(90deg, color-mix(in oklab, var(--on-board), transparent 94%) 0 1px, transparent 1px 40px);
  -webkit-mask-image: radial-gradient(140% 110% at 22% 12%, #000 38%, transparent 82%);
  mask-image: radial-gradient(140% 110% at 22% 12%, #000 38%, transparent 82%);
}
/* Amber track line — the board's ongoing ambient standby */
[data-design="b"] .cn-hero__track {
  position: absolute;
  left: 0;
  right: 0;
  top: 32%;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--signal) 50%, transparent) no-repeat;
  background-size: 30% 100%;
  animation: b-hero-standby 11s var(--ease-roll) infinite;
}
[data-design="b"] .cn-hero__inner {
  position: relative;
  z-index: 1;
  max-width: var(--col-max);
  margin-inline: auto;
  display: grid;
  gap: var(--col);
}
/* Headline — TEXT ELEMENT 1 — opacity:1 at first paint */
[data-design="b"] .cn-hero__name {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-display);
  line-height: var(--lh-display);
  letter-spacing: var(--tr-board);
  color: var(--on-board);
  margin: 0;
  text-wrap: balance;
  opacity: 1;
}
/* Subtitle — TEXT ELEMENT 2 — opacity:1 at first paint */
[data-design="b"] .cn-hero__knownfor {
  font-family: var(--face-text);
  font-size: var(--type-lead);
  line-height: var(--lh-lead);
  color: var(--on-board-2);
  margin: 0;
  max-width: var(--reading);
  opacity: 1;
}
/* Proof point — TEXT ELEMENT 3 — opacity:1 at first paint */
[data-design="b"] .cn-hero__signal {
  display: flex;
  align-items: center;
  gap: var(--tile-pad);
  font-family: var(--face-text);
  font-weight: 600;
  font-size: var(--type-title);
  color: var(--on-board);
  margin: 0;
  padding-top: var(--unit);
  border-top: 2px solid var(--signal);
  max-width: var(--reading);
  opacity: 1;
}
[data-design="b"] .cn-pip {
  width: 9px;
  height: 9px;
  flex: none;
  border-radius: var(--r-pip);
  background: var(--signal-2);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--signal), transparent 80%);
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 2 — CTA row (below hero, above pointer)
   data-mf-role="cta"
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-hero-cta-row {
  background: var(--board);
  padding: 0 var(--col) var(--gutter);
  display: flex;
  align-items: center;
  gap: var(--gutter);
  flex-wrap: wrap;
}
[data-design="b"] .cn-hero-phone {
  font-family: var(--face-mono);
  font-size: var(--type-caption);
  letter-spacing: .05em;
  color: var(--on-board-2);
}
[data-design="b"] .cn-hero-phone a {
  color: var(--on-board-2);
  text-decoration: none;
}

/* ── Primary Cut ───────────────────────────────────────────────────────  */
[data-design="b"] .cn-cut--primary {
  position: relative;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  gap: var(--hinge-gap);
  min-height: 56px;
  padding: var(--unit) var(--gutter);
  border-radius: var(--r-cut);
  isolation: isolate;
  overflow: hidden;
  background: var(--secondary);
  color: var(--on-board);
  font-family: var(--face-text);
  font-weight: 600;
  font-size: var(--type-body);
  text-decoration: none;
  box-shadow: var(--board-recess);
  transition: transform var(--t-tick) var(--ease-seat), box-shadow var(--t-quick) var(--ease-seat);
  cursor: pointer;
  border: 0;
}
[data-design="b"] .cn-cut__track {
  position: absolute;
  inset: auto 0 0 0;
  height: 2px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--signal) 50%, transparent) no-repeat;
  background-size: 42% 100%;
  animation: b-cta-track 6.5s var(--ease-roll) infinite;
}
[data-design="b"] .cn-cut__chev {
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform-origin: center top;
  transition: max-width var(--t-quick) var(--ease-seat), opacity var(--t-quick) var(--ease-seat);
}
[data-design="b"] .cn-cut--primary:active {
  transform: translateY(2px) scale(.99);
}
[data-design="b"] .cn-cut--primary:focus-visible {
  outline: none;
  box-shadow: var(--tile-raise), 0 0 0 3px color-mix(in oklab, var(--signal), transparent 62%);
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 6 — Pointer (wayfinding, NOT a button)
   data-mf-role="pointer" — must be immediately before #funnel
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-pointer {
  display: grid;
  justify-items: center;
  gap: var(--hinge-gap);
  padding: var(--gutter) 0 var(--platform);
  cursor: pointer;
  background: var(--hall);
}
[data-design="b"] .cn-pointer__rail {
  position: relative;
  width: 2px;
  height: 56px;
  border-radius: var(--r-pip);
  overflow: hidden;
  background: var(--rule);
}
[data-design="b"] .cn-pointer__rail::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: -40%;
  height: 40%;
  background: linear-gradient(180deg, transparent, var(--signal));
  animation: b-track-advance 5s var(--ease-roll) infinite;
}
[data-design="b"] .cn-pointer__tile {
  font-size: 0.9rem;
  color: var(--signal);
  transform-origin: center top;
  display: inline-block;
  animation: b-pointer-tick 5s var(--ease-seat) infinite;
}
[data-design="b"] .cn-pointer__label {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  color: var(--muted);
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 5 — Funnel (5-step consultation)
   id="funnel"  data-mf-role="funnel"
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-funnel {
  background: var(--hall);
  padding: var(--hall-gap) var(--col);
}
[data-design="b"] .cn-funnel__inner {
  max-width: var(--col-max);
  margin-inline: auto;
}
[data-design="b"] .cn-funnel__board {
  background: var(--board);
  border-radius: var(--r-board);
  box-shadow: var(--board-shadow);
  padding: var(--gutter) var(--col) var(--margin);
  display: grid;
  gap: var(--gutter);
  color: var(--on-board);
}
[data-design="b"] .cn-funnel__header {
  display: grid;
  gap: var(--unit);
}
[data-design="b"] .cn-funnel__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--on-board);
  margin: 0;
}
/* Progress bar */
[data-design="b"] .cn-funnel__progress {
  display: flex;
  align-items: center;
  gap: var(--unit);
}
[data-design="b"] .cn-prog__rail {
  flex: 1;
  height: 2px;
  background: color-mix(in oklab, var(--on-board), transparent 82%);
  border-radius: var(--r-pip);
  overflow: hidden;
}
[data-design="b"] .cn-prog__fill {
  display: block;
  height: 100%;
  background: var(--signal);
  transform: scaleX(0.2);
  transform-origin: left;
  transition: transform var(--t-seat) var(--ease-roll);
}
[data-design="b"] .cn-prog__label {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  color: var(--on-board-2);
  white-space: nowrap;
}
/* Step panels */
[data-design="b"] .cn-funnel__step {
  display: grid;
  gap: var(--unit);
}
[data-design="b"] .cn-funnel__q {
  font-family: var(--face-text);
  font-size: var(--type-title);
  line-height: var(--lh-lead);
  color: var(--on-board);
  margin: 0;
}
[data-design="b"] .cn-funnel__options {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--hinge-gap);
}
/* Step transition — slides in via transform */
[data-design="b"] .cn-funnel__step.is-entering {
  animation: b-step-in var(--t-seat) var(--ease-roll) both;
}
/* Funnel option buttons */
[data-design="b"] .cn-funnel__opt {
  display: block;
  width: 100%;
  box-sizing: border-box;
  text-align: left;
  padding: var(--tile-pad) var(--unit);
  background: color-mix(in oklab, var(--on-board), transparent 92%);
  border: 1px solid color-mix(in oklab, var(--on-board), transparent 80%);
  border-radius: var(--r-tile);
  color: var(--on-board);
  font-family: var(--face-text);
  font-size: var(--type-body);
  cursor: pointer;
  min-height: 48px;
  transition: border-color var(--t-quick) var(--ease-roll), box-shadow var(--t-quick) var(--ease-roll);
}
[data-design="b"] .cn-funnel__opt.is-selected {
  background: color-mix(in oklab, var(--signal), transparent 84%);
  border-color: var(--signal);
  box-shadow: inset 0 1px 0 var(--sheen);
}
[data-design="b"] .cn-funnel__opt:focus-visible {
  outline: none;
  border-color: var(--signal);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--signal), transparent 62%);
}
/* Step 5 form */
[data-design="b"] .cn-funnel__form {
  display: grid;
  gap: var(--unit);
}
[data-design="b"] .cn-field {
  display: grid;
  gap: var(--hinge-gap);
}
[data-design="b"] .cn-field--full {
  grid-column: 1 / -1;
}
[data-design="b"] .cn-field__label {
  font-family: var(--face-text);
  font-weight: 600;
  font-size: var(--type-caption);
  color: var(--on-board-2);
}
[data-design="b"] .cn-field__input {
  box-sizing: border-box;
  width: 100%;
  min-height: 52px;
  padding: var(--tile-pad) var(--unit);
  border-radius: var(--r-well);
  background: color-mix(in oklab, var(--on-board), transparent 92%);
  border: 1px solid color-mix(in oklab, var(--on-board), transparent 78%);
  color: var(--on-board);
  font-family: var(--face-text);
  font-size: var(--type-body);
  box-shadow: var(--board-recess);
  transition: border-color var(--t-quick) var(--ease-roll), box-shadow var(--t-quick) var(--ease-roll);
}
[data-design="b"] .cn-field__input:focus-visible {
  outline: none;
  border-color: var(--signal);
  box-shadow: var(--board-recess), 0 0 0 3px color-mix(in oklab, var(--signal), transparent 64%);
}
[data-design="b"] .cn-field__input[aria-invalid="true"] {
  border-color: var(--critical);
}
[data-design="b"] .cn-field__textarea {
  min-height: 80px;
  resize: vertical;
}
[data-design="b"] .cn-field__msg {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .04em;
  color: var(--critical);
  margin: 0;
  min-height: 1.2em;
}
/* Success posted state — display:none when hidden, revealed with animation */
[data-design="b"] .cn-funnel__posted {
  display: flex;
  align-items: center;
  gap: var(--tile-pad);
  font-family: var(--face-board);
  font-weight: 650;
  font-size: var(--type-title);
  color: var(--on-board);
  padding: var(--unit);
  border-radius: var(--r-tile);
  background: color-mix(in oklab, var(--on-board), transparent 90%);
  box-shadow: var(--tile-raise);
  animation: b-flap var(--t-flap) var(--ease-seat);
  transform-origin: center top;
}
[data-design="b"] .cn-funnel__posted p { margin: 0; }
[data-design="b"] .cn-pip--ok {
  width: 9px;
  height: 9px;
  flex: none;
  border-radius: var(--r-pip);
  background: var(--success);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--success), transparent 80%);
}
[data-design="b"] .cn-funnel__disclaimer {
  font-family: var(--face-text);
  font-size: var(--type-caption);
  line-height: 1.6;
  color: var(--on-board-2);
  margin: 0;
  padding-top: var(--unit);
  border-top: 1px solid color-mix(in oklab, var(--on-board), transparent 82%);
}

/* ═══════════════════════════════════════════════════════════════════════
   PRACTICE AREAS
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-areas {
  padding: var(--hall-gap) var(--col);
  background: var(--hall);
}
[data-design="b"] .cn-areas__inner {
  max-width: var(--col-wide);
  margin-inline: auto;
  display: grid;
  gap: var(--gutter);
}
[data-design="b"] .cn-areas__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cn-areas__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--gutter);
  grid-template-columns: 1fr;
}
[data-design="b"] .cn-area-card {
  padding: var(--gutter);
  border-radius: var(--r-board);
  background: var(--tile);
  box-shadow: var(--tile-raise);
  display: grid;
  gap: var(--hinge-gap);
  opacity: 0;
  transform: translateY(12px);
}
[data-design="b"] .cn-area-card.is-revealed {
  opacity: 1;
  transform: none;
  transition: opacity var(--t-flap) var(--ease-roll), transform var(--t-flap) var(--ease-roll);
}
[data-design="b"] .cn-area-card__kicker {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  color: var(--signal);
}
[data-design="b"] .cn-area-card__name {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-title);
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cn-area-card__desc {
  font-family: var(--face-text);
  font-size: var(--type-body);
  line-height: var(--lh-body);
  color: var(--ink-2);
  margin: 0;
}

/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 4 — Proof board (Attorneys — dark board, flap rows, count roll)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-proof {
  position: relative;
  box-sizing: border-box;
  max-width: var(--col-wide);
  margin-inline: auto;
  margin-block: var(--platform);
  background: var(--board);
  box-shadow: var(--board-shadow);
  border-radius: var(--r-board);
  padding: var(--hall-gap) var(--col);
  display: grid;
  gap: var(--gutter);
  overflow: clip;
  color: var(--on-board);
}
[data-design="b"] .cn-proof__rule {
  position: absolute;
  inset-inline: var(--col);
  height: 2px;
  background: var(--signal);
  transform: scaleX(0);
  transform-origin: left;
}
[data-design="b"] .cn-proof__rule--top { top: var(--margin); }
[data-design="b"] .cn-proof__rule--bottom { bottom: var(--margin); transform-origin: right; }
[data-design="b"] .cn-proof.is-posted .cn-proof__rule {
  animation: b-draw var(--t-flap) var(--ease-roll) forwards;
}
[data-design="b"] .cn-proof__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--on-board);
  margin: 0;
}
[data-design="b"] .cn-proof__kicker {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  color: var(--on-board-2);
  margin: 0;
}
[data-design="b"] .cn-proof__press {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--hinge-gap);
  max-width: var(--reading);
}
[data-design="b"] .cn-row {
  display: flex;
  align-items: center;
  gap: var(--unit);
  perspective: 700px;
}
[data-design="b"] .cn-row__no {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .1em;
  color: var(--on-board-2);
  min-width: 2.5ch;
}
[data-design="b"] .cn-row__tile {
  font-family: var(--face-board);
  font-weight: 600;
  font-size: clamp(1.0625rem, 2.6vw, 1.375rem);
  letter-spacing: .01em;
  color: var(--ink);
  background: var(--tile);
  border-radius: var(--r-tile);
  padding: 6px var(--tile-pad);
  box-shadow: var(--tile-raise);
  position: relative;
  transform-origin: center top;
  opacity: 0;
}
[data-design="b"] .cn-row__tile::after {
  content: "";
  position: absolute;
  inset-inline: 0;
  top: 50%;
  height: 1px;
  background: var(--tile-hinge);
  pointer-events: none;
}
[data-design="b"] .cn-proof.is-posted .cn-row__tile {
  animation: b-flap var(--t-flap) var(--ease-seat) forwards;
}
[data-design="b"] .cn-proof.is-posted .cn-row:nth-child(2) .cn-row__tile { animation-delay: 90ms; }
[data-design="b"] .cn-proof.is-posted .cn-row:nth-child(3) .cn-row__tile { animation-delay: 180ms; }
[data-design="b"] .cn-proof__cell {
  display: grid;
  justify-items: start;
  gap: var(--flap);
  margin: 0;
  padding: var(--col) var(--gutter);
  justify-self: start;
  border-radius: var(--r-tile);
  background: color-mix(in oklab, var(--on-board), transparent 92%);
  box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--on-board), transparent 80%);
}
[data-design="b"] .cn-count,
[data-design="b"] .cn-count__suffix {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: clamp(3rem, 12vw, 5.25rem);
  line-height: 1;
  color: var(--on-board);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tr-board);
}
[data-design="b"] .cn-count.is-rolling { filter: blur(.4px); }
[data-design="b"] .cn-proof__cell-label {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: var(--tr-kicker);
  text-transform: uppercase;
  color: var(--on-board-2);
}

/* ═══════════════════════════════════════════════════════════════════════
   ATTORNEYS (bio section — below proof board)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-attorneys {
  padding: var(--hall-gap) var(--col);
  background: var(--hall);
}
[data-design="b"] .cn-attorneys__inner {
  max-width: var(--col-wide);
  margin-inline: auto;
  display: grid;
  gap: var(--gutter);
}
[data-design="b"] .cn-attorneys__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cn-attorney__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--margin);
}
[data-design="b"] .cn-attorney {
  display: grid;
  gap: var(--col);
  padding: var(--gutter);
  border-radius: var(--r-board);
  border: 1px solid var(--rule);
  background: var(--tile);
  opacity: 0;
  transform: translateY(10px);
}
[data-design="b"] .cn-attorney.is-revealed {
  opacity: 1;
  transform: none;
  transition: opacity var(--t-flap) var(--ease-roll), transform var(--t-flap) var(--ease-roll);
}
[data-design="b"] .cn-attorney__photo-wrap {
  width: 100%;
  max-width: 200px;
}
[data-design="b"] .cn-attorney__photo {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--r-tile);
  border: 1px solid var(--rule);
  object-fit: cover;
  aspect-ratio: 4/5;
}
[data-design="b"] .cn-attorney__bio {
  display: grid;
  gap: var(--unit);
  align-content: start;
}
[data-design="b"] .cn-attorney__name {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-title);
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cn-attorney__cred {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .04em;
  color: var(--signal);
  margin: 0;
  text-transform: uppercase;
}
[data-design="b"] .cn-attorney__text {
  font-size: var(--type-body);
  line-height: var(--lh-body);
  color: var(--ink-2);
  margin: 0;
  max-width: var(--reading);
}

/* ═══════════════════════════════════════════════════════════════════════
   TESTIMONIAL
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-testimonial {
  background: var(--board);
  padding: var(--hall-gap) var(--col);
}
[data-design="b"] .cn-testimonial__inner {
  max-width: var(--col-max);
  margin-inline: auto;
  display: grid;
  gap: var(--gutter);
}
[data-design="b"] .cn-testimonial__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--on-board);
  margin: 0;
}
[data-design="b"] .cn-testimonial__quote {
  margin: 0;
  padding: var(--gutter);
  border-left: 3px solid var(--signal);
  border-radius: 0 var(--r-board) var(--r-board) 0;
  background: color-mix(in oklab, var(--on-board), transparent 92%);
  display: grid;
  gap: var(--unit);
}
[data-design="b"] .cn-testimonial__quote p {
  font-family: var(--face-text);
  font-size: var(--type-lead);
  line-height: var(--lh-lead);
  color: var(--on-board);
  margin: 0;
  font-style: italic;
}
[data-design="b"] .cn-testimonial__quote footer {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .04em;
  color: var(--on-board-2);
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════════════════
   JURISDICTIONS
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-jurisdictions {
  padding: var(--hall-gap) var(--col);
  background: var(--hall);
}
[data-design="b"] .cn-jurisdictions__inner {
  max-width: var(--col-max);
  margin-inline: auto;
  display: grid;
  gap: var(--gutter);
}
[data-design="b"] .cn-jurisdictions__title {
  font-family: var(--face-board);
  font-weight: 700;
  font-size: var(--type-headline);
  letter-spacing: var(--tr-board);
  color: var(--ink);
  margin: 0;
}
[data-design="b"] .cn-jur__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--hinge-gap);
}
[data-design="b"] .cn-jur__item {
  display: flex;
  align-items: center;
  gap: var(--unit);
  font-family: var(--face-text);
  font-size: var(--type-body);
  color: var(--ink-2);
  padding: var(--tile-pad) var(--unit);
  border-bottom: 1px solid var(--rule);
}
[data-design="b"] .cn-jur__pip {
  width: 7px;
  height: 7px;
  flex: none;
  border-radius: var(--r-pip);
  background: var(--signal);
}

/* ═══════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-footer {
  background: var(--secondary);
  padding: var(--hall-gap) var(--col);
}
[data-design="b"] .cn-footer__inner {
  max-width: var(--col-wide);
  margin-inline: auto;
  display: grid;
  gap: var(--margin);
}
[data-design="b"] .cn-footer__firm {
  display: grid;
  gap: var(--hinge-gap);
}
[data-design="b"] .cn-footer__name {
  font-family: var(--face-board);
  font-weight: 650;
  font-size: var(--type-title);
  letter-spacing: var(--tr-board);
  color: var(--on-board);
}
[data-design="b"] .cn-footer__addr,
[data-design="b"] .cn-footer__phone,
[data-design="b"] .cn-footer__email {
  font-family: var(--face-text);
  font-size: var(--type-caption);
  color: var(--on-board-2);
  text-decoration: none;
  display: block;
}
[data-design="b"] .cn-footer__bar {
  display: grid;
  gap: var(--unit);
  padding-top: var(--gutter);
  border-top: 1px solid color-mix(in oklab, var(--on-board), transparent 82%);
}
[data-design="b"] .cn-footer__bar-text,
[data-design="b"] .cn-footer__disclaimer {
  font-family: var(--face-text);
  font-size: var(--type-caption);
  line-height: 1.65;
  color: var(--on-board-2);
  margin: 0;
}
[data-design="b"] .cn-footer__copy {
  font-family: var(--face-mono);
  font-size: var(--type-kicker);
  letter-spacing: .04em;
  color: var(--muted);
  text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════════════════
   HOVER / FOCUS TRANSFORMS — ALL inside @media (hover:hover) and (pointer:fine)
   ═══════════════════════════════════════════════════════════════════════ */
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .cn-cut--primary:hover {
    box-shadow: var(--tile-raise);
  }
  [data-design="b"] .cn-cut--primary:hover .cn-cut__chev,
  [data-design="b"] .cn-cut--primary:focus-visible .cn-cut__chev {
    max-width: 1.4em;
    opacity: 1;
    animation: b-chev-flap var(--t-seat) var(--ease-seat);
  }
  [data-design="b"] .cn-cut--primary:hover .cn-cut__track,
  [data-design="b"] .cn-cut--primary:focus-visible .cn-cut__track {
    background-image: linear-gradient(90deg, transparent, var(--signal-2) 50%, transparent);
  }
  [data-design="b"] .cn-funnel__opt:hover {
    border-color: var(--signal-2);
    box-shadow: inset 0 1px 0 var(--sheen);
  }
  [data-design="b"] .cn-index__list a:hover {
    color: var(--signal);
  }
  [data-design="b"] .cn-footer__phone:hover,
  [data-design="b"] .cn-footer__email:hover {
    color: var(--signal);
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   KEYFRAMES — ONLY transform / opacity / clip-path animated
   ZERO width / height / max-height / padding / margin / top / left etc.
   ═══════════════════════════════════════════════════════════════════════ */
@keyframes b-flap {
  0%   { transform: rotateX(-90deg); opacity: 0; }
  55%  { transform: rotateX(6deg);   opacity: 1; }
  100% { transform: rotateX(0);      opacity: 1; }
}
@keyframes b-standby-pan {
  from { background-position: -38% 0, 0 0; }
  to   { background-position: 138% 0, 0 0; }
}
@keyframes b-hero-standby {
  0%   { background-position: -30% 0; }
  100% { background-position: 130% 0; }
}
@keyframes b-cta-track {
  0%      { background-position: -42% 0; }
  60%,100%{ background-position: 142% 0; }
}
@keyframes b-chev-flap {
  0%   { transform: rotateX(-90deg); }
  60%  { transform: rotateX(6deg);   }
  100% { transform: rotateX(0);      }
}
@keyframes b-track-advance {
  0%      { transform: translateY(0);    }
  70%,100%{ transform: translateY(340%); }
}
@keyframes b-pointer-tick {
  0%,62% { transform: rotateX(0);     }
  72%    { transform: rotateX(-70deg); }
  82%    { transform: rotateX(6deg);   }
  90%,100%{ transform: rotateX(0);    }
}
@keyframes b-draw {
  to { transform: scaleX(1); }
}
@keyframes b-step-in {
  0%   { opacity: 0; transform: translateY(8px);  }
  100% { opacity: 1; transform: translateY(0);    }
}

/* ═══════════════════════════════════════════════════════════════════════
   SCROLL-LINKED PARALLAX — TRIAD-2 premium scroll motion
   Hero field and proof board shift on scroll (JS-driven via style var)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .cn-hero__field {
  will-change: transform;
}
[data-design="b"] .cn-proof {
  will-change: transform;
}

/* ═══════════════════════════════════════════════════════════════════════
   REDUCED MOTION FALLBACKS
   ═══════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .cn-wordmark .cn-char { animation: none; opacity: 1; transform: none; }
  [data-design="b"] .cn-header__standby { animation: none; opacity: .5; background-position: 50% 0, 0 0; }
  [data-design="b"] .cn-index { transition: opacity 1ms; transform: none; }
  [data-design="b"] .cn-hero__track { animation: none; opacity: .6; background-position: 50% 0; }
  [data-design="b"] .cn-proof__rule { animation: none; transform: scaleX(1); }
  [data-design="b"] .cn-row__tile { animation: none !important; opacity: 1; transform: none; }
  [data-design="b"] .cn-cut__track { animation: none; opacity: .7; background-position: 50% 0; }
  [data-design="b"] .cn-cut__chev { max-width: 1.4em; opacity: 1; }
  [data-design="b"] .cn-pointer__rail::after { animation: none; top: auto; bottom: 0; }
  [data-design="b"] .cn-pointer__tile { animation: none; }
  [data-design="b"] .cn-funnel__step.is-entering { animation: none; }
  [data-design="b"] .cn-area-card { opacity: 1; transform: none; transition: none; }
  [data-design="b"] .cn-attorney { opacity: 1; transform: none; transition: none; }
  [data-design="b"] .cn-funnel__posted { animation: none; }
  [data-design="b"] .cn-prog__fill { transition: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE — mobile-first, no h-scroll at 320/390/768/1440
   ═══════════════════════════════════════════════════════════════════════ */
@media (min-width: 640px) {
  [data-design="b"] .cn-areas__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  [data-design="b"] .cn-attorney {
    grid-template-columns: 200px 1fr;
    align-items: start;
  }
}
@media (min-width: 900px) {
  [data-design="b"] .cn-areas__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 560px) {
  [data-design="b"] .cn-header__bar { padding: var(--tile-pad) var(--unit); }
  [data-design="b"] .cn-hero { padding: var(--hall-gap) var(--unit) var(--platform); }
  [data-design="b"] .cn-hero-cta-row { padding: 0 var(--unit) var(--gutter); flex-direction: column; align-items: flex-start; }
  [data-design="b"] .cn-pointer { padding: var(--gutter) 0 var(--platform); }
  [data-design="b"] .cn-funnel { padding: var(--platform) var(--unit); }
  [data-design="b"] .cn-funnel__board { padding: var(--col) var(--unit) var(--gutter); }
  [data-design="b"] .cn-areas { padding: var(--platform) var(--unit); }
  [data-design="b"] .cn-proof { padding: var(--platform) var(--unit); margin-inline: var(--unit); }
  [data-design="b"] .cn-proof__rule { inset-inline: var(--unit); }
  [data-design="b"] .cn-attorneys { padding: var(--platform) var(--unit); }
  [data-design="b"] .cn-testimonial { padding: var(--platform) var(--unit); }
  [data-design="b"] .cn-jurisdictions { padding: var(--platform) var(--unit); }
  [data-design="b"] .cn-footer { padding: var(--platform) var(--unit); }
}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="b"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="b"] [data-mf-role="cta"] { opacity: 1 !important; }
