/* ============================================================
   DESIGN B — "Broadside" remapped to [data-design="b"]
   Pacific Construction Services, Inc. · Seattle, WA · construction
   Federalist broadside register: parchment + ink + vermillion wax seal.
   EB Garamond / Spectral / JetBrains Mono. Ink-settling motion.
   Photo substrate LOW — leans on ink-wash animation + typography.
   All selectors scoped [data-design="b"]. Keyframes prefixed b-.
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Spectral:ital,wght@0,300;0,400;0,500;1,400&family=JetBrains+Mono:wght@400;500&display=swap");

/* ---- Token system (scoped to the slice, not :root) ---- */
[data-design="b"] {
  --bd-parchment:      #F2EBDB;
  --bd-parchment-deep: #E8DEC5;
  --bd-parchment-edge: #DCD0B2;
  --bd-ink:            #1A1612;
  --bd-ink-soft:       #3A322B;
  --bd-ink-mute:       #6B5F50;
  --bd-vermillion:     #B33A2A;
  --bd-vermillion-deep:#8A2A1E;
  --bd-oxblood:        #5C2018;
  --bd-brass:          #A6864A;
  --bd-foxing:         #9B8869;
  --bd-rule:           rgba(26,22,18,.32);
  --bd-rule-faint:     rgba(26,22,18,.14);

  /* required exposed token */
  --design-b-primary:  var(--bd-vermillion);

  --bd-display: "EB Garamond", Georgia, serif;
  --bd-body:    "Spectral", Georgia, serif;
  --bd-mono:    "JetBrains Mono", ui-monospace, monospace;

  --bd-hair:   1px;
  --bd-tight:  4px;
  --bd-snug:   8px;
  --bd-margin: 16px;
  --bd-gutter: 24px;
  --bd-bay:    40px;
  --bd-stanza: 64px;
  --bd-chapter:96px;
  --bd-folio:  144px;

  --bd-ease-settle:   cubic-bezier(.22,.61,.36,1);
  --bd-ease-register: cubic-bezier(.4,0,.2,1);
  --bd-ease-unfurl:   cubic-bezier(.16,.84,.44,1);
  --bd-d-press:    120ms;
  --bd-d-register: 220ms;
  --bd-d-settle:   420ms;
  --bd-d-unfurl:   640ms;

  --bd-r-seal: 50%;
  --bd-r-leaf: 2px;
}

/* ---- Base / reset within the slice ---- */
[data-design="b"].dq-design,
[data-design="b"] .dq-design { display: block; }

[data-design="b"] {
  background: var(--bd-parchment);
  color: var(--bd-ink-soft);
  font-family: var(--bd-body);
  font-size: clamp(17px, 1.5vw, 20px);
  line-height: 1.58;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
[data-design="b"] *,
[data-design="b"] *::before,
[data-design="b"] *::after { box-sizing: border-box; }

[data-design="b"] h1,
[data-design="b"] h2,
[data-design="b"] h3 { font-family: var(--bd-display); font-weight: 500; color: var(--bd-ink); margin: 0; line-height: 1.06; }
[data-design="b"] p { margin: 0; }
[data-design="b"] a { color: inherit; }
[data-design="b"] em { font-style: italic; }

[data-design="b"] .b-eyebrow {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--bd-ink-mute);
}
[data-design="b"] .b-h2 { font-size: clamp(34px, 5.2vw, 60px); letter-spacing: -.008em; }
[data-design="b"] .b-lede { color: var(--bd-ink-soft); max-width: 60ch; margin-top: var(--bd-margin); }
[data-design="b"] .b-inline-link { color: var(--bd-vermillion-deep); text-decoration: underline; text-underline-offset: 3px; }
[data-design="b"] .b-inline-link:hover { color: var(--bd-vermillion); }
[data-design="b"] .b-visually-hidden {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ============================================================
   ELEMENT 1 — Animated minimalist header (ink-wash registration)
   ============================================================ */
[data-design="b"] .b-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--bd-parchment);
  border-bottom: 1px solid var(--bd-rule);
  isolation: isolate; overflow: hidden;
}
[data-design="b"] .b-header__wash {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(140% 220% at 8% 50%, rgba(179,58,42,.10), transparent 55%),
    radial-gradient(120% 200% at 92% 50%, rgba(166,134,74,.14), transparent 60%),
    linear-gradient(90deg, rgba(26,22,18,.04), transparent 30%, transparent 70%, rgba(26,22,18,.04));
  animation: b-header-wash 27s var(--bd-ease-settle) infinite alternate;
}
[data-design="b"] .b-header__rule {
  position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; z-index: 1;
  background: linear-gradient(90deg, transparent, var(--bd-vermillion) 18%, var(--bd-oxblood) 50%, var(--bd-vermillion) 82%, transparent);
  transform: scaleX(0); transform-origin: left center; opacity: .9;
  animation: b-header-rule-draw 1100ms 200ms var(--bd-ease-settle) forwards,
             b-header-rule-breath 31s 1500ms var(--bd-ease-settle) infinite;
}
@keyframes b-header-wash {
  0%,100% { background-position: 0% 50%, 100% 50%, 0 0; }
  50%     { background-position: 6% 48%, 94% 52%, 0 0; }
}
@keyframes b-header-rule-draw { to { transform: scaleX(1); } }
@keyframes b-header-rule-breath { 0%,100% { opacity: .9; } 50% { opacity: .55; } }

[data-design="b"] .b-header__bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--bd-gutter);
  max-width: 1480px; margin: 0 auto;
  padding: 18px clamp(20px, 4vw, 48px);
}
[data-design="b"] .b-logo { display: flex; flex-direction: column; gap: 2px; text-decoration: none; min-width: 0; }
[data-design="b"] .b-logo__mark {
  font-family: var(--bd-display); font-weight: 600; color: var(--bd-ink);
  font-size: clamp(18px, 2.4vw, 23px); letter-spacing: -.01em; line-height: 1.1;
}
[data-design="b"] .b-logo__amp { color: var(--bd-vermillion-deep); font-style: italic; }
[data-design="b"] .b-logo__seal {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--bd-ink-mute);
}

[data-design="b"] .b-menu-btn {
  display: flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 48px; height: 44px; padding: 0 11px;
  background: transparent; border: 1px solid var(--bd-rule); cursor: pointer;
  transition: background var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .b-menu-btn span { display: block; height: 1.5px; background: var(--bd-ink); transition: transform var(--bd-d-settle) var(--bd-ease-settle); }
[data-design="b"] .b-menu-btn:hover { background: var(--bd-parchment-deep); }
[data-design="b"] .b-menu-btn:focus-visible { outline: 2px solid var(--bd-vermillion); outline-offset: 2px; }

/* ---- Drawer (tipped-in note) ---- */
[data-design="b"] .b-drawer {
  position: fixed; inset: 0; z-index: 60;
  display: none;
  background: rgba(26,22,18,.42);
}
[data-design="b"] .b-drawer[data-open="true"] { display: block; }
[data-design="b"] .b-drawer__inner {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(86vw, 360px);
  background: var(--bd-parchment);
  border-left: 1px solid var(--bd-rule);
  padding: clamp(24px, 6vw, 48px) clamp(20px, 5vw, 36px);
  display: flex; flex-direction: column; gap: var(--bd-stanza);
  animation: b-drawer-in var(--bd-d-unfurl) var(--bd-ease-unfurl);
}
@keyframes b-drawer-in { from { transform: translateX(16px); opacity: .4; } to { transform: translateX(0); opacity: 1; } }
[data-design="b"] .b-drawer__close {
  align-self: flex-end; width: 44px; height: 44px;
  background: transparent; border: 1px solid var(--bd-rule); color: var(--bd-ink);
  font-size: 24px; line-height: 1; cursor: pointer;
}
[data-design="b"] .b-drawer__close:hover { background: var(--bd-parchment-deep); }
[data-design="b"] .b-drawer__close:focus-visible { outline: 2px solid var(--bd-vermillion); outline-offset: 2px; }
[data-design="b"] .b-nav { display: flex; flex-direction: column; }
[data-design="b"] .b-drawer__link {
  display: flex; align-items: baseline; justify-content: space-between;
  font-family: var(--bd-display); font-size: 24px; color: var(--bd-ink);
  text-decoration: none; padding: 14px 0; border-bottom: 1px solid var(--bd-rule-faint);
  transition: padding-left var(--bd-d-register) var(--bd-ease-settle), color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .b-drawer__link small { font-family: var(--bd-mono); font-size: 11px; color: var(--bd-ink-mute); }
[data-design="b"] .b-drawer__link:hover { padding-left: 6px; color: var(--bd-vermillion-deep); }
[data-design="b"] .b-drawer__phone {
  display: flex; flex-direction: column; gap: 3px; text-decoration: none;
  padding: 16px 18px; background: var(--bd-vermillion); color: #F8EFE0;
  border: 1px solid var(--bd-vermillion-deep);
}
[data-design="b"] .b-drawer__phone-label { font-family: var(--bd-mono); font-size: 10px; letter-spacing: .2em; text-transform: uppercase; opacity: .9; }
[data-design="b"] .b-drawer__phone-value { font-family: var(--bd-display); font-size: 22px; font-weight: 600; }
[data-design="b"] .b-drawer__phone:hover { background: var(--bd-vermillion-deep); }

/* ============================================================
   ELEMENT 2 — Animated CTA (wax-seal-press) = the funnel anchor
   ============================================================ */
[data-design="b"] .b-cta {
  position: relative; display: inline-flex; align-items: center; gap: 14px;
  padding: 18px 30px 18px 28px;
  background: var(--bd-vermillion); color: #F8EFE0;
  font-family: var(--bd-display); font-size: 18px; font-weight: 600; letter-spacing: .04em;
  border: 1px solid var(--bd-vermillion-deep); text-decoration: none; isolation: isolate; cursor: pointer;
  min-height: 44px;
  box-shadow:
    inset 0 1px 0 rgba(255,220,200,.35),
    inset 0 -1px 0 rgba(0,0,0,.18),
    0 1px 0 rgba(0,0,0,.08);
  transition: transform var(--bd-d-press) var(--bd-ease-register),
              box-shadow var(--bd-d-press) var(--bd-ease-register),
              background var(--bd-d-register) var(--bd-ease-register);
  animation: b-cta-breath 5.2s var(--bd-ease-settle) infinite;
}
[data-design="b"] .b-cta__arrow {
  width: 22px; height: 11px; flex: none;
  background:
    linear-gradient(currentColor, currentColor) left center / 16px 1.5px no-repeat;
  position: relative;
}
[data-design="b"] .b-cta__arrow::after {
  content: ""; position: absolute; right: 1px; top: 50%;
  width: 7px; height: 7px; border-right: 1.5px solid currentColor; border-top: 1.5px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}
[data-design="b"] .b-cta:hover {
  background: var(--bd-vermillion-deep); transform: translateY(-1px);
  box-shadow: inset 0 1px 0 rgba(255,220,200,.45), inset 0 -2px 0 rgba(0,0,0,.22), 0 4px 0 rgba(0,0,0,.10);
}
[data-design="b"] .b-cta:active {
  transform: translateY(1px);
  box-shadow: inset 0 1px 0 rgba(0,0,0,.20), inset 0 -1px 0 rgba(255,220,200,.10), 0 0 0 rgba(0,0,0,0);
}
[data-design="b"] .b-cta:focus-visible { outline: 2px solid var(--bd-ink); outline-offset: 3px; }
@keyframes b-cta-breath {
  0%,100% { box-shadow: inset 0 1px 0 rgba(255,220,200,.35), inset 0 -1px 0 rgba(0,0,0,.18), 0 1px 0 rgba(0,0,0,.08), 0 0 0 0 rgba(179,58,42,.20); }
  50%     { box-shadow: inset 0 1px 0 rgba(255,220,200,.42), inset 0 -1px 0 rgba(0,0,0,.20), 0 1px 0 rgba(0,0,0,.08), 0 0 0 8px rgba(179,58,42,0); }
}

/* ============================================================
   ELEMENT 3 — Hero ink-wash (ONE animated layer, ambient)
   ============================================================ */
[data-design="b"] .b-hero {
  position: relative; isolation: isolate; overflow: hidden;
  padding: clamp(64px, 11vw, 132px) clamp(20px, 4vw, 48px) clamp(72px, 12vw, 140px);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .b-hero__wash { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
[data-design="b"] .b-hero__wash::before,
[data-design="b"] .b-hero__wash::after {
  content: ""; position: absolute; inset: -10%;
  filter: blur(6px); mix-blend-mode: multiply;
}
[data-design="b"] .b-hero__wash::before {
  background:
    radial-gradient(45% 35% at 25% 38%, rgba(140,42,30,.34), transparent 62%),
    radial-gradient(50% 40% at 78% 62%, rgba(166,134,74,.32), transparent 60%);
  animation: b-hero-wash-a 23s var(--bd-ease-settle) infinite alternate;
}
[data-design="b"] .b-hero__wash::after {
  background:
    radial-gradient(60% 50% at 70% 25%, rgba(26,22,18,.18), transparent 60%),
    radial-gradient(40% 40% at 18% 80%, rgba(179,58,42,.20), transparent 65%);
  animation: b-hero-wash-b 31s var(--bd-ease-settle) infinite alternate;
}
@keyframes b-hero-wash-a {
  0%   { transform: translate3d(0,0,0) scale(1); opacity: .85; }
  100% { transform: translate3d(-4%,3%,0) scale(1.06); opacity: 1; }
}
@keyframes b-hero-wash-b {
  0%   { transform: translate3d(0,0,0) scale(1); opacity: .8; }
  100% { transform: translate3d(3%,-3%,0) scale(1.07); opacity: 1; }
}
/* pause the ambient wash only once the hero has scrolled out of view (perf) */
[data-design="b"] .b-hero[data-hero-visible="false"] .b-hero__wash::before,
[data-design="b"] .b-hero[data-hero-visible="false"] .b-hero__wash::after { animation-play-state: paused; }

[data-design="b"] .b-hero__inner {
  position: relative; z-index: 2;
  max-width: 980px; margin: 0 auto;
  /* hero text visible at FIRST PAINT */
  opacity: 1;
}
[data-design="b"] .b-hero__title {
  font-size: clamp(40px, 6vw, 80px); letter-spacing: -.012em; line-height: 1.04;
  margin-top: var(--bd-margin); max-width: 16ch;
}
[data-design="b"] .b-hero__title em { color: var(--bd-vermillion-deep); }
[data-design="b"] .b-hero__lede { font-size: clamp(18px, 1.9vw, 23px); color: var(--bd-ink-soft); max-width: 54ch; margin-top: var(--bd-bay); }
[data-design="b"] .b-hero__proof {
  font-family: var(--bd-mono); font-size: 12px; letter-spacing: .12em;
  color: var(--bd-ink-mute); margin-top: var(--bd-margin); text-transform: uppercase;
}
[data-design="b"] .b-hero__actions {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--bd-gutter);
  margin-top: var(--bd-stanza);
}
[data-design="b"] .b-hero__chip {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--bd-ink-soft);
  padding: 9px 14px; border: 1px solid var(--bd-rule);
}

/* ============================================================
   ELEMENT 6 — Animated pointer (between hero & funnel)
   VISIBLY rendered: wrapper opacity 1, height >> 8px, no reveal-gate
   ============================================================ */
[data-design="b"] .b-pointer {
  position: relative; z-index: 5;
  max-width: 1480px; margin: -36px auto -24px; padding: 24px clamp(20px,4vw,48px);
  display: flex; justify-content: center; pointer-events: none;
  opacity: 1;            /* wrapper is always visible */
  min-height: 168px;     /* guarantees rendered height well above the 8px floor */
}
[data-design="b"] .b-pointer__inner {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  pointer-events: auto; text-decoration: none;
}
[data-design="b"] .b-pointer__rule {
  width: 1px; height: 116px;
  background: linear-gradient(to bottom, transparent, var(--bd-vermillion) 28%, var(--bd-vermillion-deep) 100%);
  transform-origin: top center; transform: scaleY(1);
  /* breathe only — never opacity:0 at rest */
  animation: b-pointer-breath 5.4s var(--bd-ease-settle) infinite;
}
[data-design="b"] .b-pointer__chevron {
  width: 28px; height: 18px; color: var(--bd-vermillion-deep); opacity: 1;
  animation: b-pointer-chevron-drift 5.4s var(--bd-ease-settle) infinite;
}
[data-design="b"] .b-pointer__label {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .32em;
  color: var(--bd-ink-mute); text-transform: uppercase;
}
@keyframes b-pointer-breath { 0%,100% { opacity: 1; } 50% { opacity: .55; } }
@keyframes b-pointer-chevron-drift { 0%,100% { transform: translateY(-1px); opacity: 1; } 50% { transform: translateY(3px); opacity: .6; } }

/* ============================================================
   ELEMENT 5 — Funnel (tipped-in pages, deckled-edge stack)
   ============================================================ */
[data-design="b"] .b-funnel-section {
  padding: clamp(72px,10vw,128px) clamp(20px,4vw,48px);
  background: var(--bd-parchment);
}
[data-design="b"] .b-funnel-section__head { max-width: 720px; margin: 0 auto var(--bd-stanza); }
[data-design="b"] .b-funnel-section__head h2 { margin-top: var(--bd-snug); }

[data-design="b"] .b-funnel {
  max-width: 720px; margin: 0 auto;
  background: var(--bd-parchment-deep); border: 1px solid var(--bd-ink); position: relative;
  box-shadow:
    1px 1px 0 var(--bd-parchment-edge),
    2px 2px 0 var(--bd-parchment-edge),
    3px 3px 0 var(--bd-parchment-edge);
}
[data-design="b"] .b-funnel__progress {
  display: flex; align-items: center; gap: var(--bd-margin);
  padding: 20px clamp(28px,5vw,56px) 0;
}
[data-design="b"] .b-funnel__progress-num { font-family: var(--bd-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--bd-ink-mute); white-space: nowrap; }
[data-design="b"] .b-funnel__progress-bar { position: relative; flex: 1; height: 1px; background: var(--bd-rule-faint); }
[data-design="b"] .b-funnel__progress-bar::after {
  content: ""; position: absolute; inset: 0 auto 0 0; height: 1px;
  width: var(--bd-fn-pct, 0%); background: var(--bd-vermillion);
  transition: width var(--bd-d-settle) var(--bd-ease-settle);
}
[data-design="b"] .b-funnel__steps { position: relative; padding: clamp(28px,5vw,52px); min-height: 480px; overflow: hidden; }
[data-design="b"] .b-funnel__step {
  position: absolute; inset: clamp(28px,5vw,52px);
  margin: 0; padding: 0; border: 0; min-width: 0;
  opacity: 0; pointer-events: none;
  transform: translateY(14px) rotate(.6deg);
  transition: opacity var(--bd-d-settle) var(--bd-ease-settle),
              transform var(--bd-d-settle) var(--bd-ease-unfurl);
}
[data-design="b"] .b-funnel__step[data-active="true"] {
  opacity: 1; pointer-events: auto; transform: translateY(0) rotate(0);
}
[data-design="b"] .b-funnel__q { font-family: var(--bd-display); font-size: clamp(24px,3.4vw,34px); color: var(--bd-ink); }
[data-design="b"] .b-funnel__help { color: var(--bd-ink-mute); font-size: 16px; margin-top: var(--bd-snug); }
[data-design="b"] .b-funnel__options { display: flex; flex-direction: column; gap: var(--bd-snug); margin-top: var(--bd-bay); }

[data-design="b"] .b-funnel__opt {
  position: relative; display: flex; align-items: center; justify-content: space-between;
  width: 100%; min-height: 44px; padding: 14px 18px; gap: 12px;
  background: var(--bd-parchment); border: 1px solid var(--bd-rule-faint);
  font-family: var(--bd-body); font-size: 17px; color: var(--bd-ink-soft); text-align: left; cursor: pointer;
  transition: padding-left var(--bd-d-register) var(--bd-ease-settle),
              border-color var(--bd-d-register) var(--bd-ease-register),
              background var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .b-funnel__opt::after {
  content: "\203A"; color: var(--bd-vermillion); font-size: 20px; opacity: 0;
  transition: opacity var(--bd-d-register) var(--bd-ease-register), transform var(--bd-d-register) var(--bd-ease-settle);
  transform: translateX(-4px);
}
[data-design="b"] .b-funnel__opt:hover {
  background: var(--bd-parchment-edge); padding-left: 24px; border-color: var(--bd-rule);
}
[data-design="b"] .b-funnel__opt:hover::after { opacity: 1; transform: translateX(0); }
[data-design="b"] .b-funnel__opt:focus-visible { outline: 2px solid var(--bd-vermillion); outline-offset: 2px; }

[data-design="b"] .b-funnel__field { margin-top: var(--bd-margin); }
[data-design="b"] .b-funnel__label { display: block; font-family: var(--bd-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--bd-ink-mute); margin-bottom: var(--bd-tight); }
[data-design="b"] .b-funnel__input,
[data-design="b"] .b-funnel__textarea {
  width: 100%; padding: 11px 2px; background: transparent; color: var(--bd-ink);
  border: 0; border-bottom: 1px solid var(--bd-ink); font-family: var(--bd-body); font-size: 17px;
  transition: border-color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .b-funnel__textarea { resize: vertical; }
[data-design="b"] .b-funnel__input:focus,
[data-design="b"] .b-funnel__textarea:focus { outline: none; border-bottom-color: var(--bd-vermillion); }
[data-design="b"] .b-funnel__actions { display: flex; flex-wrap: wrap; align-items: center; gap: var(--bd-margin); margin-top: var(--bd-bay); }
[data-design="b"] .b-funnel__actions--submit { justify-content: space-between; }
[data-design="b"] .b-funnel__back {
  background: transparent; border: 0; color: var(--bd-ink-mute);
  font-family: var(--bd-mono); font-size: 12px; letter-spacing: .1em; cursor: pointer; min-height: 44px; padding: 0 4px;
}
[data-design="b"] .b-funnel__back:hover { color: var(--bd-vermillion-deep); }
[data-design="b"] .b-funnel__submit {
  display: inline-flex; align-items: center; min-height: 44px; padding: 14px 26px;
  background: var(--bd-vermillion); color: #F8EFE0; border: 1px solid var(--bd-vermillion-deep);
  font-family: var(--bd-display); font-size: 17px; font-weight: 600; letter-spacing: .03em; cursor: pointer;
  transition: background var(--bd-d-register) var(--bd-ease-register), transform var(--bd-d-press) var(--bd-ease-register);
}
[data-design="b"] .b-funnel__submit:hover { background: var(--bd-vermillion-deep); transform: translateY(-1px); }
[data-design="b"] .b-funnel__submit:active { transform: translateY(1px); }
[data-design="b"] .b-funnel__submit:focus-visible { outline: 2px solid var(--bd-ink); outline-offset: 3px; }

[data-design="b"] .b-funnel__step--done { display: flex; flex-direction: column; align-items: center; text-align: center; justify-content: center; }
[data-design="b"] .b-funnel__seal {
  width: 92px; height: 92px; margin: 0 auto var(--bd-gutter); border-radius: 50%;
  background: radial-gradient(circle at 30% 28%, #D4584A, var(--bd-vermillion) 55%, var(--bd-oxblood));
  color: #FBE8D8; display: grid; place-items: center;
  font-family: var(--bd-display); font-style: italic; font-size: 30px; letter-spacing: .04em;
  border: 1px solid var(--bd-vermillion-deep);
  box-shadow: inset 0 1px 0 rgba(255,220,180,.4), inset 0 -2px 0 rgba(0,0,0,.18);
  transform: scale(0) rotate(-12deg);
}
[data-design="b"] .b-funnel__step--done[data-active="true"] .b-funnel__seal {
  animation: b-seal-press 600ms var(--bd-ease-unfurl) forwards;
}
@keyframes b-seal-press {
  0%   { transform: scale(0) rotate(-12deg); opacity: 0; }
  60%  { transform: scale(1.15) rotate(2deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}
[data-design="b"] .b-funnel__done-copy { color: var(--bd-ink-soft); max-width: 46ch; margin: var(--bd-margin) auto 0; }

[data-design="b"] .b-funnel__note {
  position: relative; max-width: 720px; margin: var(--bd-stanza) auto 0; padding-left: var(--bd-gutter);
}
[data-design="b"] .b-funnel__note-rule { position: absolute; left: 0; top: 4px; bottom: 4px; width: 2px; background: var(--bd-brass); }
[data-design="b"] .b-funnel__note p { font-size: 16px; color: var(--bd-ink-mute); }

/* ============================================================
   ELEMENT 4 — Work ledger (docket rows, draw-in underline)
   ============================================================ */
[data-design="b"] .b-work {
  padding: clamp(72px,10vw,140px) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep); border-top: 1px solid var(--bd-rule); border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .b-work__head { max-width: 1080px; margin: 0 auto var(--bd-stanza); }
[data-design="b"] .b-work__note { color: var(--bd-ink-soft); max-width: 58ch; margin-top: var(--bd-margin); }
[data-design="b"] .b-ledger { max-width: 1080px; margin: 0 auto; }
[data-design="b"] .b-ledger__row {
  display: grid; grid-template-columns: 80px 1fr 140px; gap: var(--bd-gutter); align-items: baseline;
  padding: 30px 0 30px 16px; position: relative;
  border-bottom: 1px solid var(--bd-rule-faint);
}
[data-design="b"] .b-ledger__row::after {
  content: ""; position: absolute; left: 0; bottom: -1px; height: 1px; width: 0;
  background: var(--bd-ink); transition: width 1100ms var(--bd-ease-settle);
}
[data-design="b"] .b-ledger__row[data-in="true"]::after { width: 100%; }
[data-design="b"] .b-ledger__row::before {
  content: ""; position: absolute; left: -2px; top: 38px;
  width: 8px; height: 8px; border-radius: 50%; background: var(--bd-vermillion);
  transform: scale(0); transition: transform 600ms 600ms var(--bd-ease-unfurl);
}
[data-design="b"] .b-ledger__row[data-in="true"]::before { transform: scale(1); }
[data-design="b"] .b-ledger__num { font-family: var(--bd-mono); font-size: 13px; color: var(--bd-ink-mute); letter-spacing: .08em; }
[data-design="b"] .b-ledger__title { font-family: var(--bd-display); font-size: clamp(22px,3vw,30px); color: var(--bd-ink); display: flex; flex-direction: column; gap: var(--bd-snug); }
[data-design="b"] .b-ledger__title small { font-family: var(--bd-body); font-size: 16px; font-weight: 400; color: var(--bd-ink-soft); line-height: 1.5; }
[data-design="b"] .b-ledger__kind { font-family: var(--bd-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--bd-vermillion-deep); }

[data-design="b"] .b-work__cta {
  max-width: 1080px; margin: var(--bd-chapter) auto 0;
  display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--bd-gutter);
  padding-top: var(--bd-stanza); border-top: 1px solid var(--bd-rule);
}
[data-design="b"] .b-work__cta-text { font-family: var(--bd-display); font-size: clamp(20px,2.6vw,28px); font-style: italic; color: var(--bd-ink); max-width: 30ch; }

/* ============================================================
   PROCESS
   ============================================================ */
[data-design="b"] .b-process { padding: clamp(72px,10vw,128px) clamp(20px,4vw,48px); }
[data-design="b"] .b-process__head { max-width: 1080px; margin: 0 auto var(--bd-stanza); }
[data-design="b"] .b-phases {
  list-style: none; margin: 0 auto; padding: 0; max-width: 1080px;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 32px;
}
[data-design="b"] .b-phase { padding-top: var(--bd-margin); border-top: 2px solid var(--bd-ink); }
[data-design="b"] .b-phase__num { font-family: var(--bd-mono); font-size: 12px; color: var(--bd-vermillion-deep); letter-spacing: .14em; }
[data-design="b"] .b-phase__title { font-family: var(--bd-display); font-size: 23px; color: var(--bd-ink); margin-top: var(--bd-snug); }
[data-design="b"] .b-phase__text { font-size: 16px; color: var(--bd-ink-soft); margin-top: var(--bd-snug); }

/* ============================================================
   ABOUT / FIRM
   ============================================================ */
[data-design="b"] .b-firm {
  padding: clamp(72px,10vw,128px) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep); border-top: 1px solid var(--bd-rule);
  display: grid; grid-template-columns: 1fr; gap: var(--bd-chapter);
  max-width: 1180px; margin: 0 auto;
}
[data-design="b"] .b-firm__body { color: var(--bd-ink-soft); max-width: 60ch; margin-top: var(--bd-bay); }
[data-design="b"] .b-firm__body:first-of-type { margin-top: var(--bd-bay); }
[data-design="b"] .b-firm__card-frame {
  background: var(--bd-parchment); border: 1px solid var(--bd-ink); padding: clamp(28px,4vw,40px);
  box-shadow: 1px 1px 0 var(--bd-parchment-edge), 2px 2px 0 var(--bd-parchment-edge), 3px 3px 0 var(--bd-parchment-edge);
}
[data-design="b"] .b-firm__stat-figure { font-family: var(--bd-display); font-size: clamp(48px,7vw,72px); color: var(--bd-vermillion-deep); line-height: 1; }
[data-design="b"] .b-firm__stat-label { font-family: var(--bd-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--bd-ink-mute); margin-top: var(--bd-snug); }
[data-design="b"] .b-firm__card-rule { display: block; height: 1px; background: var(--bd-rule); margin: var(--bd-bay) 0; }
[data-design="b"] .b-firm__facts { margin: 0; display: flex; flex-direction: column; gap: var(--bd-margin); }
[data-design="b"] .b-firm__fact { display: flex; flex-direction: column; gap: 2px; }
[data-design="b"] .b-firm__fact dt { font-family: var(--bd-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: var(--bd-ink-mute); }
[data-design="b"] .b-firm__fact dd { margin: 0; font-family: var(--bd-display); font-size: 19px; color: var(--bd-ink); }

/* ============================================================
   SERVICE AREA
   ============================================================ */
[data-design="b"] .b-area { padding: clamp(72px,10vw,120px) clamp(20px,4vw,48px); }
[data-design="b"] .b-area__head { max-width: 1080px; margin: 0 auto; }

/* ============================================================
   FOOTER (Colophon, ink-on-dark)
   ============================================================ */
[data-design="b"] .b-footer {
  background: var(--bd-ink); color: var(--bd-parchment);
  padding: clamp(64px,9vw,112px) clamp(20px,4vw,48px) clamp(40px,6vw,64px);
}
[data-design="b"] .b-footer__top {
  max-width: 1180px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: var(--bd-stanza);
}
[data-design="b"] .b-footer__name { font-family: var(--bd-display); font-size: clamp(26px,3.4vw,38px); color: var(--bd-parchment); }
[data-design="b"] .b-footer__amp { color: var(--bd-vermillion); font-style: italic; }
[data-design="b"] .b-footer__line { color: var(--bd-foxing); margin-top: var(--bd-margin); max-width: 48ch; }
[data-design="b"] .b-footer__contact { display: flex; flex-direction: column; gap: 2px; }
[data-design="b"] .b-footer__row {
  display: flex; justify-content: space-between; gap: var(--bd-margin);
  padding: 14px 0; border-bottom: 1px solid rgba(242,235,219,.14); text-decoration: none; min-height: 44px; align-items: baseline;
}
[data-design="b"] .b-footer__row-label { font-family: var(--bd-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--bd-foxing); }
[data-design="b"] .b-footer__row-value { font-family: var(--bd-display); font-size: 20px; color: var(--bd-parchment); }
[data-design="b"] a.b-footer__row:hover .b-footer__row-value { color: var(--bd-vermillion); }
[data-design="b"] .b-footer__row--cta .b-footer__row-value { color: #E9B7A4; }
[data-design="b"] .b-footer__rule { max-width: 1180px; margin: var(--bd-stanza) auto 0; height: 1px; background: rgba(242,235,219,.2); }
[data-design="b"] .b-footer__legal {
  max-width: 1180px; margin: var(--bd-gutter) auto 0;
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--bd-margin);
}
[data-design="b"] .b-footer__copy,
[data-design="b"] .b-footer__fine { font-family: var(--bd-mono); font-size: 11px; letter-spacing: .08em; color: var(--bd-foxing); }

/* ============================================================
   Responsive (≥760px / ≥880px)
   ============================================================ */
@media (min-width: 760px) {
  [data-design="b"] .b-ledger__row { grid-template-columns: 80px 1fr 160px; }
  [data-design="b"] .b-firm { grid-template-columns: 1.4fr 1fr; align-items: start; }
  [data-design="b"] .b-footer__top { grid-template-columns: 1.3fr 1fr; align-items: start; }
}
@media (max-width: 759px) {
  [data-design="b"] .b-ledger__row { grid-template-columns: 56px 1fr; row-gap: var(--bd-snug); }
  [data-design="b"] .b-ledger__kind { grid-column: 2; }
  [data-design="b"] .b-funnel__steps { min-height: 540px; }
}

/* ============================================================
   Reduced-motion fallbacks (functionality never broken)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .b-header__wash,
  [data-design="b"] .b-header__rule,
  [data-design="b"] .b-hero__wash::before,
  [data-design="b"] .b-hero__wash::after,
  [data-design="b"] .b-cta,
  [data-design="b"] .b-pointer__rule,
  [data-design="b"] .b-pointer__chevron { animation: none !important; }
  [data-design="b"] .b-header__rule { transform: scaleX(1); }
  [data-design="b"] .b-funnel__step { transition-duration: 100ms !important; transform: none !important; }
  [data-design="b"] .b-funnel__step:not([data-active="true"]) { opacity: 0; }
  [data-design="b"] .b-funnel__seal { animation: none !important; transform: none !important; opacity: 1 !important; }
  [data-design="b"] .b-ledger__row::after { transition-duration: 200ms !important; }
  [data-design="b"] .b-ledger__row::before { transition-duration: 200ms !important; }
  [data-design="b"] .b-pointer__rule,
  [data-design="b"] .b-pointer__chevron { opacity: 1 !important; }
}

/* ============================================================
   Mobile defensive overflow (MANDATORY — bottom of file)
   ============================================================ */
[data-design="b"].dq-design,
[data-design="b"] .dq-design { max-width: 100%; overflow-x: clip; }
[data-design="b"] * { min-width: 0; }
[data-design="b"] img,
[data-design="b"] svg:not([data-keep-size]) { max-width: 100%; height: auto; }

/* 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; }
