/* ============================================================
   DESIGN B — One-Way Construction NW
   Derived from Broadside grammar, remapped to a drafting-blueprint
   + weathered-timber register (architectural construction).
   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');

[data-design="b"] {
  /* ---- Color tokens (~14, construction-rooted: blueprint slate + cedar) ---- */
  --b-paper:        #ECEEF1;  /* surface — cool drafting paper */
  --b-paper-deep:   #E0E4EA;  /* elevated — funnel / scope cards */
  --b-paper-edge:   #CBD2DC;  /* deckled edge / inset outlines */
  --b-ink:          #14202B;  /* ink primary — headlines, footer field */
  --b-ink-soft:     #2B3A48;  /* body text */
  --b-ink-mute:     #5E6B79;  /* caption / mono */
  --b-blueprint:    #1F5C8C;  /* primary accent — drafting blue */
  --b-blueprint-dp: #163F60;  /* hover / deeper accent */
  --b-cedar:        #B0552B;  /* seal accent — CTA fill, hairline draw-in */
  --b-cedar-deep:   #8A3F1D;  /* CTA hover */
  --b-brass:        #9C8242;  /* restrained gilt — rule emphasis */
  --b-foxing:       #8A93A0;  /* muted mid-tone / disabled */
  --b-rule:         rgba(20,32,43,.30);
  --b-rule-faint:   rgba(20,32,43,.13);

  /* exposed primary for A/B harness */
  --design-b-primary: var(--b-blueprint);

  --b-display: "EB Garamond", Georgia, serif;
  --b-body:    "Spectral", Georgia, serif;
  --b-mono:    "JetBrains Mono", ui-monospace, monospace;

  /* spacing — 4px scale */
  --b-hair: 1px; --b-tight: 4px; --b-snug: 8px; --b-margin: 16px;
  --b-gutter: 24px; --b-bay: 40px; --b-stanza: 64px;
  --b-chapter: 96px; --b-folio: 144px;

  /* motion */
  --b-ease-settle:   cubic-bezier(.22,.61,.36,1);
  --b-ease-register: cubic-bezier(.4,0,.2,1);
  --b-ease-unfurl:   cubic-bezier(.16,.84,.44,1);
  --b-d-press: 120ms; --b-d-register: 220ms; --b-d-settle: 420ms; --b-d-unfurl: 640ms;

  color: var(--b-ink-soft);
  background: var(--b-paper);
  font-family: var(--b-body);
  font-size: clamp(17px, 1.5vw, 20px);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

[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, [data-design="b"] h4 {
  font-family: var(--b-display); font-weight: 500; color: var(--b-ink);
  margin: 0; line-height: 1.06; letter-spacing: -.008em;
}
[data-design="b"] p { margin: 0; }
[data-design="b"] em { font-style: italic; color: var(--b-blueprint-dp); }
[data-design="b"] .vl-eyebrow {
  font-family: var(--b-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--b-ink-mute); margin: 0 0 var(--b-margin);
}

/* ============================================================
   ELEMENT 1 — header: ink-wash registration (single wash layer)
   ============================================================ */
[data-design="b"] .vl-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--b-paper);
  border-bottom: 1px solid var(--b-rule);
  isolation: isolate; overflow: hidden;
}
[data-design="b"] .vl-header__wash {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background:
    radial-gradient(140% 220% at 8% 50%, rgba(31,92,140,.12), transparent 55%),
    radial-gradient(120% 200% at 92% 50%, rgba(156,130,66,.12), transparent 60%),
    linear-gradient(90deg, rgba(20,32,43,.05), transparent 30%, transparent 70%, rgba(20,32,43,.05));
  animation: b-header-wash 27s var(--b-ease-settle) infinite alternate;
}
[data-design="b"] .vl-header__rule {
  position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; z-index: 1;
  background: linear-gradient(90deg, transparent, var(--b-blueprint) 18%, var(--b-cedar) 50%, var(--b-blueprint) 82%, transparent);
  transform: scaleX(0); transform-origin: left center; opacity: .9;
  animation: b-header-rule-draw 1100ms 200ms var(--b-ease-settle) forwards,
             b-header-rule-breath 31s 1500ms var(--b-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: .5; } }

[data-design="b"] .vl-header__bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--b-gutter);
  max-width: 1480px; margin: 0 auto;
  padding: 18px clamp(16px, 4vw, 48px);
}
[data-design="b"] .vl-logo { text-decoration: none; display: inline-flex; align-items: baseline; }
[data-design="b"] .vl-logo__mark {
  font-family: var(--b-display); font-weight: 600; color: var(--b-ink);
  font-size: clamp(19px, 2.4vw, 25px); letter-spacing: -.01em;
}
[data-design="b"] .vl-logo__amp { color: var(--b-cedar); font-style: italic; }
[data-design="b"] .vl-logo__nw { color: var(--b-blueprint); }

[data-design="b"] .vl-menu-btn {
  width: 46px; height: 46px; min-width: 46px; padding: 0;
  background: transparent; border: 1px solid var(--b-rule); cursor: pointer;
  display: grid; place-items: center; position: relative;
  transition: background var(--b-d-register) var(--b-ease-register);
}
[data-design="b"] .vl-menu-btn:hover { background: var(--b-paper-deep); }
[data-design="b"] .vl-menu-btn span,
[data-design="b"] .vl-menu-btn span::before,
[data-design="b"] .vl-menu-btn span::after {
  content: ""; display: block; width: 20px; height: 1.5px; background: var(--b-ink);
  position: relative; transition: transform var(--b-d-settle) var(--b-ease-unfurl), opacity var(--b-d-press);
}
[data-design="b"] .vl-menu-btn span::before { position: absolute; top: -6px; left: 0; }
[data-design="b"] .vl-menu-btn span::after  { position: absolute; top: 6px; left: 0; }
[data-design="b"] .vl-menu-btn[aria-expanded="true"] span { background: transparent; }
[data-design="b"] .vl-menu-btn[aria-expanded="true"] span::before { transform: translateY(6px) rotate(45deg); }
[data-design="b"] .vl-menu-btn[aria-expanded="true"] span::after  { transform: translateY(-6px) rotate(-45deg); }

/* ---- drawer (tipped-in note) ---- */
[data-design="b"] .vl-drawer { position: fixed; inset: 0; z-index: 60; display: none; }
[data-design="b"] .vl-drawer[data-open="true"] { display: block; }
[data-design="b"] .vl-drawer__backdrop { position: absolute; inset: 0; background: rgba(20,32,43,.5); }
[data-design="b"] .vl-drawer__inner {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(86vw, 360px); background: var(--b-paper-deep);
  border-left: 1px solid var(--b-ink);
  padding: clamp(28px, 6vw, 56px) clamp(24px, 5vw, 40px);
  display: flex; flex-direction: column; gap: var(--b-margin);
  animation: b-drawer-in var(--b-d-unfurl) var(--b-ease-unfurl);
}
@keyframes b-drawer-in { from { transform: translateX(12px); opacity: .4; } to { transform: none; opacity: 1; } }
[data-design="b"] .vl-drawer__x {
  align-self: flex-end; width: 44px; height: 44px; background: transparent;
  border: 1px solid var(--b-rule); color: var(--b-ink); font-size: 24px; line-height: 1;
  cursor: pointer; margin-bottom: var(--b-snug);
}
[data-design="b"] .vl-drawer__inner a {
  text-decoration: none; color: var(--b-ink); font-family: var(--b-display);
  font-size: 22px; padding: 6px 0 6px 0;
  display: flex; justify-content: space-between; align-items: baseline;
  border-bottom: 1px solid var(--b-rule-faint);
  transition: padding-left var(--b-d-register) var(--b-ease-settle), color var(--b-d-register);
}
[data-design="b"] .vl-drawer__inner a small { font-family: var(--b-mono); font-size: 11px; color: var(--b-ink-mute); }
[data-design="b"] .vl-drawer__inner a:hover { padding-left: 6px; color: var(--b-blueprint-dp); }
[data-design="b"] .vl-drawer__cta {
  margin-top: var(--b-snug); background: var(--b-cedar); color: #F6ECE2 !important;
  border: 1px solid var(--b-cedar-deep) !important; padding: 14px 18px !important;
  justify-content: center !important; font-weight: 600; letter-spacing: .03em;
}
[data-design="b"] .vl-drawer__cta:hover { padding-left: 18px !important; background: var(--b-cedar-deep); }
[data-design="b"] .vl-drawer__tel { color: var(--b-blueprint) !important; font-size: 18px !important; border-bottom: none !important; }

/* ============================================================
   ELEMENT 3 — hero: ONE animated ink-wash layer (arrival + ambient)
   ============================================================ */
[data-design="b"] .vl-hero {
  position: relative; isolation: isolate; overflow: hidden;
  padding: clamp(56px,9vw,120px) clamp(20px,4vw,48px) clamp(72px,10vw,128px);
  border-bottom: 1px solid var(--b-rule);
  background:
    /* static blueprint grid beneath the single moving layer */
    linear-gradient(rgba(31,92,140,.05) 1px, transparent 1px) 0 0 / 100% 32px,
    linear-gradient(90deg, rgba(31,92,140,.05) 1px, transparent 1px) 0 0 / 32px 100%,
    var(--b-paper);
}
/* the single MOVING substrate layer */
[data-design="b"] .vl-hero__wash {
  position: absolute; inset: -12%; z-index: 0; pointer-events: none;
  filter: blur(8px); mix-blend-mode: multiply;
  background:
    radial-gradient(46% 38% at 24% 36%, rgba(31,92,140,.34), transparent 62%),
    radial-gradient(50% 42% at 80% 64%, rgba(156,130,66,.26), transparent 60%),
    radial-gradient(40% 38% at 64% 22%, rgba(176,85,43,.20), transparent 64%);
  opacity: 0; transform: translate3d(0,0,0) scale(1.02);
  animation:
    b-hero-arrive 1500ms var(--b-ease-settle) forwards,
    b-hero-drift 24s 1500ms var(--b-ease-settle) infinite alternate;
}
@keyframes b-hero-arrive { from { opacity: 0; transform: translate3d(0,3%,0) scale(1.05); } to { opacity: 1; transform: translate3d(0,0,0) scale(1.02); } }
@keyframes b-hero-drift {
  0%   { transform: translate3d(0,0,0) scale(1.02); }
  100% { transform: translate3d(-3%,2%,0) scale(1.07); }
}

[data-design="b"] .vl-hero__inner {
  position: relative; z-index: 2;
  max-width: 1480px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr; gap: var(--b-stanza);
}
@media (min-width: 880px) {
  [data-design="b"] .vl-hero__inner { grid-template-columns: 1fr 340px; gap: clamp(40px,5vw,80px); align-items: start; }
}
[data-design="b"] .vl-hero__title {
  font-size: clamp(40px, 6vw, 80px); line-height: 1.04; letter-spacing: -.012em;
  max-width: 17ch; opacity: 1;
}
[data-design="b"] .vl-hero__lede {
  margin-top: var(--b-bay); max-width: 56ch; font-size: clamp(17px,1.6vw,21px);
  color: var(--b-ink-soft); opacity: 1;
}
[data-design="b"] .vl-hero__actions {
  margin-top: var(--b-stanza); display: flex; flex-wrap: wrap; gap: var(--b-gutter); align-items: center;
}
[data-design="b"] .vl-hero__meta { font-family: var(--b-mono); font-size: 11px; letter-spacing: .14em; color: var(--b-ink-mute); text-transform: uppercase; }
[data-design="b"] .vl-hero__side {
  margin: 0; padding: var(--b-gutter); background: rgba(224,228,234,.62);
  border: 1px solid var(--b-paper-edge);
  box-shadow: 1px 1px 0 var(--b-paper-edge), 2px 2px 0 var(--b-paper-edge), 3px 3px 0 var(--b-paper-edge);
}
[data-design="b"] .vl-hero__folio { font-family: var(--b-mono); font-size: 11px; letter-spacing: .22em; color: var(--b-cedar); border-bottom: 1px solid var(--b-rule-faint); padding-bottom: var(--b-snug); margin-bottom: var(--b-margin); }
[data-design="b"] .vl-hero__pair { padding: var(--b-snug) 0; border-bottom: 1px solid var(--b-rule-faint); }
[data-design="b"] .vl-hero__pair:last-child { border-bottom: none; }
[data-design="b"] .vl-hero__pair dt { font-family: var(--b-display); font-size: 19px; color: var(--b-ink); }
[data-design="b"] .vl-hero__pair dd { margin: 2px 0 0; font-size: 14px; color: var(--b-ink-mute); }

/* ============================================================
   ELEMENT 2 — CTA: cedar seal-press
   ============================================================ */
[data-design="b"] .vl-cta {
  position: relative; display: inline-flex; align-items: center; gap: 14px;
  padding: 18px 30px; min-height: 44px;
  background: var(--b-cedar); color: #F8EFE6;
  font-family: var(--b-display); font-size: 18px; font-weight: 600; letter-spacing: .04em;
  border: 1px solid var(--b-cedar-deep); text-decoration: none; isolation: isolate; cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,228,205,.32), inset 0 -1px 0 rgba(0,0,0,.18), 0 1px 0 rgba(0,0,0,.08);
  transition: transform var(--b-d-press) var(--b-ease-register),
              box-shadow var(--b-d-press) var(--b-ease-register),
              background var(--b-d-register) var(--b-ease-register);
  animation: b-cta-breath 5.2s var(--b-ease-settle) infinite;
}
[data-design="b"] .vl-cta__arrow { width: 16px; height: 1.5px; background: currentColor; position: relative; }
[data-design="b"] .vl-cta__arrow::after { content: ""; position: absolute; right: 0; top: -3px; width: 7px; height: 7px; border-top: 1.5px solid currentColor; border-right: 1.5px solid currentColor; transform: rotate(45deg); }
[data-design="b"] .vl-cta:hover { background: var(--b-cedar-deep); transform: translateY(-1px); box-shadow: inset 0 1px 0 rgba(255,228,205,.42), inset 0 -2px 0 rgba(0,0,0,.22), 0 4px 0 rgba(0,0,0,.10); }
[data-design="b"] .vl-cta:active { transform: translateY(1px); box-shadow: inset 0 1px 0 rgba(0,0,0,.20), inset 0 -1px 0 rgba(255,228,205,.10); }
[data-design="b"] .vl-cta:focus-visible { outline: 2px solid var(--b-ink); outline-offset: 3px; }
@keyframes b-cta-breath {
  0%,100% { box-shadow: inset 0 1px 0 rgba(255,228,205,.32), inset 0 -1px 0 rgba(0,0,0,.18), 0 1px 0 rgba(0,0,0,.08), 0 0 0 0 rgba(176,85,43,.22); }
  50%     { box-shadow: inset 0 1px 0 rgba(255,228,205,.40), inset 0 -1px 0 rgba(0,0,0,.20), 0 1px 0 rgba(0,0,0,.08), 0 0 0 8px rgba(176,85,43,0); }
}

/* ============================================================
   ELEMENT 6 — pointer: drafted dimension-line (NOT a button)
   ============================================================ */
[data-design="b"] .vl-pointer {
  position: relative; z-index: 5;
  max-width: 1480px; margin: -36px auto -24px; padding: 0 clamp(20px,4vw,48px);
  display: flex; justify-content: center; pointer-events: none;
}
[data-design="b"] .vl-pointer__inner { display: flex; flex-direction: column; align-items: center; gap: 12px; pointer-events: none; }
[data-design="b"] .vl-pointer__dim { width: 20px; height: 130px; color: var(--b-blueprint); display: block; transform-origin: top center; opacity: 1;
  animation: b-pointer-draw 1400ms 700ms var(--b-ease-settle) both, b-pointer-breath 5.6s 2300ms var(--b-ease-settle) infinite; }
[data-design="b"] .vl-pointer__dim svg { width: 20px; height: 130px; display: block; }
[data-design="b"] .vl-pointer__label {
  font-family: var(--b-mono); font-size: 10px; letter-spacing: .32em; color: var(--b-ink-mute);
  text-transform: uppercase; opacity: 1;
}
@keyframes b-pointer-draw { from { transform: scaleY(.18); } to { transform: scaleY(1); } }
@keyframes b-pointer-breath { 0%,100% { opacity: 1; } 50% { opacity: .55; } }

/* ============================================================
   ELEMENT 5 — funnel (tipped-in pages, deckled-edge stack)
   ============================================================ */
[data-design="b"] .vl-funnel-section {
  padding: clamp(64px,10vw,128px) clamp(20px,4vw,48px);
  background: var(--b-paper);
}
[data-design="b"] .vl-funnel-section__head { max-width: 720px; margin: 0 auto var(--b-bay); text-align: left; }
[data-design="b"] .vl-funnel-section__title { font-size: clamp(34px,5vw,60px); }
[data-design="b"] .vl-funnel-section__note { margin-top: var(--b-margin); color: var(--b-ink-soft); max-width: 60ch; }
[data-design="b"] .vl-funnel {
  max-width: 720px; margin: 0 auto; position: relative;
  background: var(--b-paper-deep); border: 1px solid var(--b-ink);
  box-shadow: 1px 1px 0 var(--b-paper-edge), 2px 2px 0 var(--b-paper-edge), 3px 3px 0 var(--b-paper-edge);
}
[data-design="b"] .vl-funnel__progress {
  display: flex; align-items: center; gap: var(--b-margin);
  padding: var(--b-gutter) clamp(24px,5vw,48px) 0;
}
[data-design="b"] .vl-funnel__progress-num { font-family: var(--b-mono); font-size: 11px; letter-spacing: .2em; color: var(--b-ink-mute); text-transform: uppercase; white-space: nowrap; }
[data-design="b"] .vl-funnel__progress-bar { position: relative; flex: 1; height: 2px; background: var(--b-rule-faint); }
[data-design="b"] .vl-funnel__progress-bar::after { content: ""; position: absolute; inset: 0 auto 0 0; width: var(--b-fn-pct, 0%); background: var(--b-blueprint); transition: width var(--b-d-settle) var(--b-ease-settle); }
[data-design="b"] .vl-funnel__steps { position: relative; padding: clamp(28px,5vw,52px); min-height: 440px; overflow: hidden; }
[data-design="b"] .vl-funnel__step {
  position: absolute; inset: clamp(28px,5vw,52px); margin: 0; padding: 0; border: 0;
  opacity: 0; pointer-events: none; transform: translateY(14px) rotate(.6deg);
  transition: opacity var(--b-d-settle) var(--b-ease-settle), transform var(--b-d-settle) var(--b-ease-unfurl);
}
[data-design="b"] .vl-funnel__step[data-active="true"] { opacity: 1; pointer-events: auto; transform: translateY(0) rotate(0); }
[data-design="b"] .vl-funnel__step h3 { font-size: clamp(24px,3vw,34px); margin-bottom: var(--b-snug); }
[data-design="b"] .vl-funnel__step > p { color: var(--b-ink-mute); margin-bottom: var(--b-gutter); font-size: 16px; }
[data-design="b"] .vl-funnel__options { display: flex; flex-direction: column; gap: 10px; }
[data-design="b"] .vl-funnel__opt {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  width: 100%; min-height: 44px; text-align: left;
  padding: 14px 18px; background: var(--b-paper); color: var(--b-ink);
  border: 1px solid var(--b-rule-faint); font-family: var(--b-body); font-size: 17px; cursor: pointer;
  transition: padding-left var(--b-d-register) var(--b-ease-settle), border-color var(--b-d-register), background var(--b-d-register);
}
[data-design="b"] .vl-funnel__opt:hover { padding-left: 24px; background: #F4F6F9; border-color: var(--b-blueprint); }
[data-design="b"] .vl-funnel__opt:focus-visible { outline: 2px solid var(--b-blueprint); outline-offset: 2px; }
[data-design="b"] .vl-funnel__arrow { color: var(--b-cedar); font-size: 13px; opacity: 0; transition: opacity var(--b-d-register), transform var(--b-d-register) var(--b-ease-register); transform: translateX(-4px); }
[data-design="b"] .vl-funnel__opt:hover .vl-funnel__arrow { opacity: 1; transform: translateX(0); }
[data-design="b"] .vl-funnel__field { margin-bottom: var(--b-margin); }
[data-design="b"] .vl-funnel__field label { display: block; font-family: var(--b-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--b-ink-mute); margin-bottom: 6px; }
[data-design="b"] .vl-funnel__opt-tag { text-transform: none; letter-spacing: 0; color: var(--b-foxing); }
[data-design="b"] .vl-funnel__field input,
[data-design="b"] .vl-funnel__field textarea {
  width: 100%; background: var(--b-paper); border: none; border-bottom: 1.5px solid var(--b-rule);
  font-family: var(--b-body); font-size: 17px; color: var(--b-ink); padding: 8px 2px; resize: vertical;
  transition: border-color var(--b-d-register);
}
[data-design="b"] .vl-funnel__field input:focus,
[data-design="b"] .vl-funnel__field textarea:focus { outline: none; border-bottom-color: var(--b-blueprint); }
[data-design="b"] .vl-funnel__actions { margin-top: var(--b-gutter); display: flex; flex-wrap: wrap; gap: var(--b-margin); align-items: center; }
[data-design="b"] .vl-funnel__actions--submit { justify-content: space-between; }
[data-design="b"] .vl-funnel__back { background: transparent; border: none; color: var(--b-ink-mute); font-family: var(--b-mono); font-size: 12px; letter-spacing: .1em; cursor: pointer; padding: 10px 4px; min-height: 44px; }
[data-design="b"] .vl-funnel__back:hover { color: var(--b-ink); }
[data-design="b"] .vl-cta--submit { font-size: 16px; padding: 14px 22px; }

[data-design="b"] .vl-funnel__done { text-align: center; }
[data-design="b"] .vl-funnel__seal {
  width: 92px; height: 92px; margin: 0 auto var(--b-gutter); border-radius: 50%;
  background: radial-gradient(circle at 30% 28%, #C9703F, var(--b-cedar) 55%, var(--b-cedar-deep));
  color: #FBE8D8; display: grid; place-items: center;
  font-family: var(--b-display); font-style: italic; font-size: 30px; font-weight: 500;
  border: 1px solid var(--b-cedar-deep);
  box-shadow: inset 0 1px 0 rgba(255,224,190,.4), inset 0 -2px 0 rgba(0,0,0,.18);
  animation: b-seal-press 600ms var(--b-ease-unfurl) both;
}
@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"] .vl-funnel__writ { margin-top: var(--b-gutter); display: flex; flex-direction: column; align-items: center; gap: var(--b-snug); }
[data-design="b"] .vl-funnel__writ span { color: var(--b-ink-mute); font-size: 15px; }
[data-design="b"] .vl-funnel__tel { font-family: var(--b-display); font-size: 26px; color: var(--b-blueprint); text-decoration: none; }
[data-design="b"] .vl-funnel__tel:hover { color: var(--b-blueprint-dp); }
[data-design="b"] .vl-funnel-section__after { max-width: 720px; margin: var(--b-bay) auto 0; font-family: var(--b-mono); font-size: 12px; letter-spacing: .04em; color: var(--b-ink-mute); line-height: 1.7; }

/* ============================================================
   ELEMENT 4 — scope ledger (mid-page ambient: drawn rules + seal-dot)
   ============================================================ */
[data-design="b"] .vl-scope {
  padding: clamp(72px,10vw,140px) clamp(20px,4vw,48px);
  background: var(--b-paper-deep); border-top: 1px solid var(--b-rule); border-bottom: 1px solid var(--b-rule);
}
[data-design="b"] .vl-scope__head, [data-design="b"] .vl-process__head { max-width: 1480px; margin: 0 auto var(--b-stanza); }
[data-design="b"] .vl-scope__title, [data-design="b"] .vl-process__title { font-size: clamp(32px,4.6vw,56px); }
[data-design="b"] .vl-scope__note, [data-design="b"] .vl-process__note { margin-top: var(--b-margin); max-width: 64ch; color: var(--b-ink-soft); }
[data-design="b"] .vl-ledger { max-width: 1480px; margin: 0 auto; }
[data-design="b"] .vl-ledger__row {
  display: grid; grid-template-columns: 88px 1fr 160px; gap: var(--b-gutter); align-items: baseline;
  padding: 32px 0; position: relative; border-bottom: 1px solid var(--b-rule-faint);
}
[data-design="b"] .vl-ledger__row::after { content: ""; position: absolute; left: 0; bottom: -1px; height: 1px; width: 0; background: var(--b-ink); transition: width 1100ms var(--b-ease-settle); }
[data-design="b"] .vl-ledger__row[data-in="true"]::after { width: 100%; }
[data-design="b"] .vl-ledger__row::before { content: ""; position: absolute; left: -16px; top: 38px; width: 8px; height: 8px; border-radius: 50%; background: var(--b-cedar); transform: scale(0); transition: transform 600ms 600ms var(--b-ease-unfurl); }
[data-design="b"] .vl-ledger__row[data-in="true"]::before { transform: scale(1); }
[data-design="b"] .vl-ledger__num { font-family: var(--b-mono); font-size: 12px; letter-spacing: .18em; color: var(--b-blueprint); }
[data-design="b"] .vl-ledger__title { font-size: clamp(22px,2.6vw,30px); display: flex; flex-direction: column; gap: 10px; }
[data-design="b"] .vl-ledger__title small { font-family: var(--b-body); font-weight: 400; font-size: 17px; color: var(--b-ink-soft); line-height: 1.55; max-width: 60ch; }
[data-design="b"] .vl-ledger__tag { font-family: var(--b-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--b-ink-mute); text-align: right; }
[data-design="b"] .vl-scope__cta { max-width: 1480px; margin: var(--b-stanza) auto 0; }
@media (max-width: 760px) {
  [data-design="b"] .vl-ledger__row { grid-template-columns: 56px 1fr; row-gap: 10px; }
  [data-design="b"] .vl-ledger__tag { grid-column: 2; text-align: left; }
}

/* ---- PROCESS ---- */
[data-design="b"] .vl-process { padding: clamp(72px,10vw,140px) clamp(20px,4vw,48px); }
[data-design="b"] .vl-process__list { max-width: 1480px; margin: 0 auto; list-style: none; padding: 0; display: grid; gap: 32px; grid-template-columns: 1fr; counter-reset: none; }
@media (min-width: 760px) { [data-design="b"] .vl-process__list { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); } }
[data-design="b"] .vl-process__phase { position: relative; padding: var(--b-gutter); background: var(--b-paper-deep); border: 1px solid var(--b-paper-edge); }
[data-design="b"] .vl-process__mark { font-family: var(--b-mono); font-size: 12px; letter-spacing: .2em; color: var(--b-cedar); }
[data-design="b"] .vl-process__phase h3 { font-size: 22px; margin: var(--b-snug) 0; }
[data-design="b"] .vl-process__phase p { font-size: 16px; color: var(--b-ink-soft); line-height: 1.55; }

/* ---- ABOUT ---- */
[data-design="b"] .vl-about { padding: clamp(72px,10vw,140px) clamp(20px,4vw,48px); background: var(--b-paper-deep); border-top: 1px solid var(--b-rule); display: grid; gap: var(--b-stanza); grid-template-columns: 1fr; max-width: 1480px; margin: 0 auto; }
@media (min-width: 760px) { [data-design="b"] .vl-about { grid-template-columns: 1fr 2fr; gap: clamp(40px,5vw,80px); align-items: start; } }
[data-design="b"] .vl-about__panel { aspect-ratio: 4 / 5; background: var(--b-paper); border: 1px solid var(--b-paper-edge); box-shadow: 1px 1px 0 var(--b-paper-edge), 2px 2px 0 var(--b-paper-edge), 3px 3px 0 var(--b-paper-edge); display: grid; place-items: center; max-width: 320px; width: 100%; }
[data-design="b"] .vl-about__monogram { font-family: var(--b-display); font-style: italic; font-size: 88px; color: rgba(31,92,140,.18); }
[data-design="b"] .vl-about__title { font-size: clamp(28px,3.6vw,46px); margin-bottom: var(--b-gutter); max-width: 22ch; }
[data-design="b"] .vl-about__copy p { margin-bottom: var(--b-margin); max-width: 64ch; color: var(--b-ink-soft); }
[data-design="b"] .vl-about__tel { display: inline-block; margin-top: var(--b-margin); font-family: var(--b-display); font-size: 22px; color: var(--b-cedar); text-decoration: none; border-bottom: 1px solid var(--b-cedar); padding-bottom: 2px; }
[data-design="b"] .vl-about__tel:hover { color: var(--b-cedar-deep); }

/* ---- SERVICE AREA ---- */
[data-design="b"] .vl-area { padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px); max-width: 1480px; margin: 0 auto; }
[data-design="b"] .vl-area__title { font-size: clamp(28px,3.6vw,46px); margin-bottom: var(--b-margin); }
[data-design="b"] .vl-area__body { max-width: 60ch; color: var(--b-ink-soft); }

/* ---- FOOTER (Colophon) ---- */
[data-design="b"] .vl-footer { background: var(--b-ink); color: #C6CDD6; padding: clamp(56px,8vw,96px) clamp(20px,4vw,48px) var(--b-stanza); }
[data-design="b"] .vl-footer__grid { max-width: 1480px; margin: 0 auto; display: grid; grid-template-columns: 1fr; gap: var(--b-bay); }
@media (min-width: 760px) { [data-design="b"] .vl-footer__grid { grid-template-columns: 2fr 1fr 1fr 1fr; gap: var(--b-gutter); } }
[data-design="b"] .vl-footer__mark { font-family: var(--b-display); font-size: 24px; color: #ECEEF1; }
[data-design="b"] .vl-footer__amp { color: var(--b-cedar); font-style: italic; }
[data-design="b"] .vl-footer__tagline { margin-top: var(--b-snug); font-family: var(--b-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--b-foxing); }
[data-design="b"] .vl-footer__col h4 { font-family: var(--b-mono); font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--b-foxing); margin-bottom: var(--b-margin); font-weight: 500; }
[data-design="b"] .vl-footer__col a, [data-design="b"] .vl-footer__col span { display: block; color: #C6CDD6; text-decoration: none; font-size: 15px; padding: 5px 0; }
[data-design="b"] .vl-footer__col a:hover { color: var(--b-cedar); }
[data-design="b"] .vl-footer__rule { max-width: 1480px; margin: var(--b-stanza) auto 0; padding-top: var(--b-gutter); border-top: 1px solid rgba(255,255,255,.12); display: flex; flex-wrap: wrap; justify-content: space-between; gap: var(--b-margin); font-family: var(--b-mono); font-size: 11px; letter-spacing: .08em; color: var(--b-foxing); }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .vl-header__wash,
  [data-design="b"] .vl-header__rule,
  [data-design="b"] .vl-hero__wash,
  [data-design="b"] .vl-cta,
  [data-design="b"] .vl-pointer__dim,
  [data-design="b"] .vl-drawer__inner { animation: none !important; }
  [data-design="b"] .vl-hero__wash { opacity: 1 !important; transform: none !important; }
  [data-design="b"] .vl-pointer__dim { transform: none !important; opacity: 1 !important; }
  [data-design="b"] .vl-funnel__step { transition-duration: 100ms !important; transform: none !important; }
  [data-design="b"] .vl-funnel__seal { animation: none !important; transform: none !important; opacity: 1 !important; }
  [data-design="b"] .vl-ledger__row::after,
  [data-design="b"] .vl-ledger__row::before { transition-duration: 200ms !important; }
}

/* ============================================================
   MOBILE NO-H-SCROLL GUARD (mandatory, at BOTTOM)
   ============================================================ */
[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; }
