/* ═══════════════════════════════════════════════════════════════════════
   design-b — Broadside × Handy Hernandez × Las Vegas Construction
   All selectors scoped to [data-design="b"]
   Keyframes prefixed: b-
   Custom property exposed: --design-b-primary
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── Design tokens ─────────────────────────────────────────────────── */
:root {
  --design-b-primary: #B33A2A;
}

[data-design="b"] {
  /* Palette — Broadside */
  --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);

  /* Typography */
  --bd-display: "EB Garamond", "Garamond", Georgia, serif;
  --bd-body:    "Spectral", Georgia, serif;
  --bd-mono:    "JetBrains Mono", "Courier New", monospace;

  /* Spacing */
  --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;

  /* Motion */
  --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;

  /* Radius */
  --bd-r-none: 0;
  --bd-r-seal: 50%;
  --bd-r-leaf: 2px;

  font-family: var(--bd-body);
  background: var(--bd-parchment);
  color: var(--bd-ink-soft);
  box-sizing: border-box;
}

[data-design="b"] *,
[data-design="b"] *::before,
[data-design="b"] *::after {
  box-sizing: border-box;
}

/* ─── Global reset for this scope ───────────────────────────────────── */
[data-design="b"] h1,
[data-design="b"] h2,
[data-design="b"] h3,
[data-design="b"] p,
[data-design="b"] ul,
[data-design="b"] ol,
[data-design="b"] dl,
[data-design="b"] fieldset {
  margin: 0; padding: 0; border: none;
}
[data-design="b"] ul,
[data-design="b"] ol { list-style: none; }
[data-design="b"] a { color: inherit; text-decoration: none; }
[data-design="b"] button { cursor: pointer; background: none; border: none; font: inherit; }


/* ─── Eyebrow ───────────────────────────────────────────────────────── */
[data-design="b"] .vl-eyebrow {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
  margin-bottom: var(--bd-snug);
}


/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 1 — Animated minimalist header
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-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"] .vl-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"] .vl-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"] .vl-header__bar {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(20px,4vw,48px);
  height: 64px;
}
[data-design="b"] .vl-logo {
  display: flex;
  flex-direction: column;
  gap: 2px;
  text-decoration: none;
}
[data-design="b"] .vl-logo__mark {
  font-family: var(--bd-display);
  font-size: clamp(18px,2.2vw,24px);
  font-weight: 500;
  color: var(--bd-ink);
  letter-spacing: .01em;
  line-height: 1;
}
[data-design="b"] .vl-logo__seal {
  font-family: var(--bd-mono);
  font-size: 9px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
}
@media (max-width: 560px) {
  [data-design="b"] .vl-logo__seal { display: none; }
}

/* Hamburger button */
[data-design="b"] .vl-menu-btn {
  width: 44px;
  height: 44px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  color: var(--bd-ink);
  border: 1px solid transparent;
  transition:
    background var(--bd-d-register) var(--bd-ease-register),
    border-color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-menu-btn:hover {
  background: var(--bd-parchment-deep);
  border-color: var(--bd-rule);
}
[data-design="b"] .vl-menu-btn > span,
[data-design="b"] .vl-menu-btn > span::before,
[data-design="b"] .vl-menu-btn > span::after {
  display: block;
  width: 22px;
  height: 1.5px;
  background: currentColor;
  transition: transform var(--bd-d-settle) var(--bd-ease-unfurl);
}
[data-design="b"] .vl-menu-btn > span { position: relative; }
[data-design="b"] .vl-menu-btn > span::before,
[data-design="b"] .vl-menu-btn > span::after {
  content: "";
  position: absolute;
  left: 0;
}
[data-design="b"] .vl-menu-btn > span::before { top: -6px; }
[data-design="b"] .vl-menu-btn > span::after  { top:  6px; }
[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 (display:none when closed) ─────────────────────────────── */
[data-design="b"] .vl-drawer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 60;
}
[data-design="b"] .vl-drawer[data-open="true"] {
  display: flex;
}
[data-design="b"] .vl-drawer__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(26,22,18,.55);
  cursor: pointer;
}
[data-design="b"] .vl-drawer__inner {
  position: relative;
  margin-left: auto;
  width: min(340px, 85vw);
  height: 100%;
  background: var(--bd-parchment);
  border-left: 1px solid var(--bd-rule);
  padding: 24px 32px 40px;
  display: flex;
  flex-direction: column;
  gap: 32px;
  overflow-y: auto;
  animation: b-drawer-slide-in var(--bd-d-unfurl) var(--bd-ease-unfurl) both;
}
@keyframes b-drawer-slide-in {
  from { transform: translateX(100%); }
  to   { transform: translateX(0); }
}
[data-design="b"] .vl-drawer__close {
  align-self: flex-end;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: var(--bd-ink-mute);
  border: 1px solid var(--bd-rule);
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-drawer__close:hover { color: var(--bd-ink); }
[data-design="b"] .vl-drawer__nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
[data-design="b"] .vl-drawer__nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  font-family: var(--bd-display);
  font-size: clamp(20px, 2.8vw, 26px);
  color: var(--bd-ink);
  border-bottom: 1px solid var(--bd-rule-faint);
  transition: padding-left var(--bd-d-register) var(--bd-ease-register),
              color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-drawer__nav a:hover {
  padding-left: 6px;
  color: var(--bd-vermillion-deep);
}
[data-design="b"] .vl-drawer__nav a small {
  font-family: var(--bd-mono);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--bd-ink-mute);
}
[data-design="b"] .vl-drawer__ctas {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: auto;
}
[data-design="b"] .vl-drawer__phone {
  font-family: var(--bd-mono);
  font-size: 16px;
  letter-spacing: .1em;
  color: var(--bd-ink-mute);
  padding: 12px 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}


/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 2 — CTA (wax-seal-press)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-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;
  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"] .vl-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"] .vl-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"] .vl-cta:focus-visible { outline: 2px solid var(--bd-ink); outline-offset: 3px; }

[data-design="b"] .vl-cta--ghost {
  background: transparent;
  color: var(--bd-vermillion);
  border-color: var(--bd-vermillion);
  box-shadow: none;
  animation: none;
}
[data-design="b"] .vl-cta--ghost:hover {
  background: var(--bd-vermillion);
  color: #F8EFE0;
}

[data-design="b"] .vl-cta__arrow {
  display: inline-block;
  width: 18px;
  height: 12px;
  background: currentColor;
  clip-path: polygon(0 40%, 60% 40%, 60% 0%, 100% 50%, 60% 100%, 60% 60%, 0 60%);
  transition: transform var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-cta:hover .vl-cta__arrow { transform: translateX(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 + dimension-line blueprint backdrop)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding:
    clamp(72px,9vw,128px)
    clamp(20px,4vw,48px)
    clamp(96px,11vw,152px);
  border-bottom: 1px solid var(--bd-rule);
  background: var(--bd-parchment);
}

/* Ink-wash substrate (two coprime layers, sustained ambient) */
[data-design="b"] .vl-hero__wash {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
[data-design="b"] .vl-hero__wash::before,
[data-design="b"] .vl-hero__wash::after {
  content: "";
  position: absolute;
  inset: -10%;
  filter: blur(6px);
  mix-blend-mode: multiply;
}
[data-design="b"] .vl-hero__wash::before {
  background:
    radial-gradient(45% 35% at 25% 38%, rgba(140,42,30,.32), transparent 62%),
    radial-gradient(50% 40% at 78% 62%, rgba(166,134,74,.30), transparent 60%);
  animation: b-hero-wash-a 23s var(--bd-ease-settle) infinite alternate;
}
[data-design="b"] .vl-hero__wash::after {
  background:
    radial-gradient(60% 50% at 70% 25%, rgba(26,22,18,.16), transparent 60%),
    radial-gradient(40% 40% at 18% 80%, rgba(179,58,42,.18), 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: .9; }
  100% { transform: translate3d(-3%,2%,0) scale(1.04); opacity: 1; }
}
@keyframes b-hero-wash-b {
  0%   { transform: translate3d(0,0,0) scale(1);    opacity: .85; }
  100% { transform: translate3d(2%,-2%,0) scale(1.05); opacity: 1; }
}

/* Blueprint dimension-line unique hero animation */
[data-design="b"] .vl-hero__blueprint {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}
[data-design="b"] .vl-hero__blueprint-svg {
  width: 100%;
  height: 100%;
}

/* Horizontal dimension lines — draw in left-to-right */
[data-design="b"] .bp-h1 {
  stroke-dasharray: 1200;
  stroke-dashoffset: 1200;
  animation: b-bp-draw-h 2.4s 0.4s var(--bd-ease-settle) forwards,
             b-bp-pulse 19s 3s var(--bd-ease-settle) infinite;
}
[data-design="b"] .bp-h2 {
  stroke-dasharray: 700;
  stroke-dashoffset: 700;
  animation: b-bp-draw-h2 2.0s 0.8s var(--bd-ease-settle) forwards,
             b-bp-pulse 23s 3s var(--bd-ease-settle) infinite;
}
[data-design="b"] .bp-h3 {
  stroke-dasharray: 900;
  stroke-dashoffset: 900;
  animation: b-bp-draw-h3 1.8s 1.2s var(--bd-ease-settle) forwards,
             b-bp-pulse 27s 3s var(--bd-ease-settle) infinite;
}
/* Vertical lines */
[data-design="b"] .bp-v1 {
  stroke-dasharray: 500;
  stroke-dashoffset: 500;
  animation: b-bp-draw-v 1.6s 1.6s var(--bd-ease-settle) forwards,
             b-bp-pulse 23s 3.2s var(--bd-ease-settle) infinite;
}
[data-design="b"] .bp-v2 {
  stroke-dasharray: 500;
  stroke-dashoffset: 500;
  animation: b-bp-draw-v 1.6s 1.8s var(--bd-ease-settle) forwards,
             b-bp-pulse 23s 3.4s var(--bd-ease-settle) infinite;
}
[data-design="b"] .bp-v3 {
  stroke-dasharray: 500;
  stroke-dashoffset: 500;
  animation: b-bp-draw-v 1.4s 2.0s var(--bd-ease-settle) forwards,
             b-bp-pulse 31s 3.6s var(--bd-ease-settle) infinite;
}
/* Tick marks */
[data-design="b"] .bp-tick {
  opacity: 0;
  animation: b-bp-fade-in 0.5s 2.4s var(--bd-ease-settle) forwards,
             b-bp-pulse 19s 3s var(--bd-ease-settle) infinite;
}
[data-design="b"] .bp-t2 { animation-delay: 2.6s, 3s; }
/* Arc */
[data-design="b"] .bp-arc {
  stroke-dasharray: 1000;
  stroke-dashoffset: 1000;
  animation: b-bp-draw-arc 2.8s 1.0s var(--bd-ease-settle) forwards,
             b-bp-pulse 27s 4s var(--bd-ease-settle) infinite;
}
/* Registration corners */
[data-design="b"] .bp-reg {
  opacity: 0;
  animation: b-bp-fade-in 0.6s 2.2s var(--bd-ease-settle) forwards;
}
[data-design="b"] .bp-r2 { animation-delay: 2.4s; }
/* Annotation text */
[data-design="b"] .bp-anno {
  opacity: 0;
  animation: b-bp-fade-in 0.8s 2.8s var(--bd-ease-settle) forwards;
}

@keyframes b-bp-draw-h   { to { stroke-dashoffset: 0; } }
@keyframes b-bp-draw-h2  { to { stroke-dashoffset: 0; } }
@keyframes b-bp-draw-h3  { to { stroke-dashoffset: 0; } }
@keyframes b-bp-draw-v   { to { stroke-dashoffset: 0; } }
@keyframes b-bp-draw-arc { to { stroke-dashoffset: 0; } }
@keyframes b-bp-fade-in  { to { opacity: 1; } }
@keyframes b-bp-pulse    { 0%,100% { opacity: 1; } 50% { opacity: .6; } }

/* Hero closing thread (vermillion hairline — no directional meaning, closing register) */
[data-design="b"] .vl-hero__thread {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  z-index: 3;
  background: linear-gradient(90deg, transparent 10%, var(--bd-vermillion) 50%, transparent 90%);
  transform: scaleX(0);
  transform-origin: center;
  animation: b-hero-thread-draw 1600ms 350ms var(--bd-ease-settle) forwards;
}
@keyframes b-hero-thread-draw { to { transform: scaleX(1); } }

/* Hero inner layout */
[data-design="b"] .vl-hero__inner {
  position: relative;
  z-index: 4;
  display: grid;
  grid-template-columns: 1fr clamp(220px,28vw,360px);
  gap: clamp(32px,4vw,64px);
  align-items: start;
  max-width: 1300px;
  margin: 0 auto;
}
@media (max-width: 800px) {
  [data-design="b"] .vl-hero__inner {
    grid-template-columns: 1fr;
  }
  [data-design="b"] .vl-hero__side {
    display: none;
  }
}

/* Hero text — opacity:1 at first paint (no initially-hidden) */
[data-design="b"] .vl-hero__content {
  opacity: 1;
}
[data-design="b"] .vl-hero__title {
  font-family: var(--bd-display);
  font-size: clamp(44px,6vw,84px);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: -0.012em;
  color: var(--bd-ink);
  margin: var(--bd-snug) 0 var(--bd-margin);
}
[data-design="b"] .vl-hero__title em {
  font-style: italic;
  color: var(--bd-vermillion-deep);
}
[data-design="b"] .vl-hero__lede {
  font-family: var(--bd-body);
  font-size: clamp(17px,1.5vw,21px);
  line-height: 1.58;
  color: var(--bd-ink-soft);
  max-width: 54ch;
  margin-bottom: var(--bd-bay);
}
[data-design="b"] .vl-hero__actions {
  display: flex;
  flex-direction: column;
  gap: var(--bd-margin);
  align-items: flex-start;
}
[data-design="b"] .vl-hero__meta {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
}

/* Hero side index (colophon-style dl) */
[data-design="b"] .vl-hero__side {
  padding: clamp(20px,2.5vw,28px);
  background: var(--bd-parchment-deep);
  border: 1px solid var(--bd-rule);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--bd-margin) var(--bd-gutter);
}
[data-design="b"] .vl-hero__side dt {
  font-family: var(--bd-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-vermillion);
  grid-column: 1 / -1;
  padding-top: var(--bd-margin);
  border-top: 1px solid var(--bd-rule-faint);
}
[data-design="b"] .vl-hero__side dt:first-of-type { padding-top: 0; border-top: none; }
[data-design="b"] .vl-hero__side dd {
  font-family: var(--bd-body);
  font-size: 14px;
  color: var(--bd-ink-soft);
  grid-column: 1 / -1;
  margin: 0;
}


/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 6 — Pointer (dignified drafted-measured wayfinding)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-pointer {
  position: relative;
  z-index: 5;
  max-width: 1480px;
  margin: -48px auto -32px;
  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: 14px;
  pointer-events: auto;
  padding: 20px 0;
  min-height: 180px; /* gate: height strictly >8px */
}
[data-design="b"] .vl-pointer__rule {
  width: 1px;
  height: 120px;
  background: linear-gradient(to bottom, transparent, var(--bd-vermillion) 30%, var(--bd-vermillion-deep) 100%);
  transform-origin: top center;
  animation:
    b-pointer-draw 1400ms 1100ms var(--bd-ease-settle) both,
    b-pointer-breath 5.4s 2500ms var(--bd-ease-settle) infinite;
}
[data-design="b"] .vl-pointer__chevron {
  width: 28px;
  height: 18px;
  color: var(--bd-vermillion-deep);
  opacity: 0;
  animation: b-pointer-glyph-breath 5.4s 2500ms var(--bd-ease-settle) infinite;
  animation-fill-mode: forwards;
}
[data-design="b"] .vl-pointer__label {
  font-family: var(--bd-mono);
  font-size: 10px;
  letter-spacing: .32em;
  color: var(--bd-ink-mute);
  text-transform: uppercase;
  margin-top: 6px;
  opacity: 0;
  animation: b-pointer-label-in 900ms 2200ms var(--bd-ease-settle) forwards;
}

@keyframes b-pointer-draw    { from { transform: scaleY(0); } to { transform: scaleY(1); } }
@keyframes b-pointer-breath  { 0%,100% { opacity: 1; } 50% { opacity: .55; } }
@keyframes b-pointer-glyph-breath {
  0%         { opacity: 0; transform: translateY(-2px); }
  20%,100%   { opacity: 1; transform: translateY(0); }
  60%        { opacity: .55; transform: translateY(2px); }
}
@keyframes b-pointer-label-in { to { opacity: 1; } }


/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 5 — Funnel (5-step tipped-in-pages consultation)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-funnel-section {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-funnel-section__head {
  max-width: 720px;
  margin: 0 auto var(--bd-chapter);
  text-align: center;
}
[data-design="b"] .vl-funnel-section__head h2 {
  font-family: var(--bd-display);
  font-size: clamp(36px,5.2vw,64px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-margin);
}
[data-design="b"] .vl-funnel-section__head p {
  font-size: clamp(16px,1.4vw,19px);
  color: var(--bd-ink-mute);
}
[data-design="b"] .vl-funnel {
  max-width: 720px;
  margin: 0 auto;
  background: var(--bd-parchment-deep);
  border: 1px solid var(--bd-ink);
  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"] .vl-funnel__progress {
  display: flex;
  align-items: center;
  gap: var(--bd-margin);
  padding: 16px clamp(28px,5vw,56px);
  border-bottom: 1px solid var(--bd-rule-faint);
}
[data-design="b"] .vl-funnel__progress-num {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
  white-space: nowrap;
}
[data-design="b"] .vl-funnel__progress-bar {
  flex: 1;
  height: 2px;
  background: var(--bd-rule-faint);
  overflow: hidden;
}
[data-design="b"] .vl-funnel__progress-fill {
  display: block;
  height: 100%;
  width: var(--bd-fn-pct, 0%);
  background: var(--bd-vermillion);
  transition: width var(--bd-d-settle) var(--bd-ease-settle);
}

[data-design="b"] .vl-funnel__steps {
  position: relative;
  padding: clamp(28px,5vw,56px);
  min-height: 460px;
  overflow: hidden;
}
[data-design="b"] .vl-funnel__step {
  position: absolute;
  inset: clamp(28px,5vw,56px);
  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"] .vl-funnel__step[data-active="true"] {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0) rotate(0);
}
[data-design="b"] .vl-funnel__step legend {
  float: left;
  width: 100%;
}
[data-design="b"] .vl-funnel__step h3 {
  font-family: var(--bd-display);
  font-size: clamp(22px,2.8vw,32px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-snug);
  line-height: 1.2;
}
[data-design="b"] .vl-funnel__help {
  font-size: 14px;
  color: var(--bd-ink-mute);
  margin-bottom: var(--bd-bay);
}
[data-design="b"] .vl-funnel__options {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
[data-design="b"] .vl-funnel__opt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  background: var(--bd-parchment);
  border: 1px solid var(--bd-rule-faint);
  color: var(--bd-ink-soft);
  font-family: var(--bd-body);
  font-size: clamp(16px,1.4vw,18px);
  text-align: left;
  cursor: pointer;
  transition:
    padding-left var(--bd-d-register) var(--bd-ease-register),
    background var(--bd-d-register) var(--bd-ease-register),
    border-color var(--bd-d-register) var(--bd-ease-register);
  min-height: 52px;
}
[data-design="b"] .vl-funnel__opt::after {
  content: "›";
  color: transparent;
  font-size: 20px;
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-funnel__opt:hover {
  padding-left: 24px;
  background: var(--bd-parchment-deep);
  border-color: var(--bd-rule);
}
[data-design="b"] .vl-funnel__opt:hover::after {
  color: var(--bd-vermillion);
}
[data-design="b"] .vl-funnel__opt:focus-visible {
  outline: 2px solid var(--bd-vermillion);
  outline-offset: 2px;
}

/* Fields (step 5) */
[data-design="b"] .vl-funnel__fields {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: var(--bd-bay);
}
[data-design="b"] .vl-funnel__label {
  display: block;
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
  margin-bottom: 6px;
}
[data-design="b"] .vl-funnel__field {
  width: 100%;
  padding: 12px 0;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--bd-ink);
  font-family: var(--bd-body);
  font-size: 16px;
  color: var(--bd-ink);
  outline: none;
  transition: border-color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-funnel__field:focus {
  border-bottom-color: var(--bd-vermillion);
}
[data-design="b"] .vl-funnel__field--textarea {
  resize: vertical;
  min-height: 100px;
}

/* Actions / back buttons */
[data-design="b"] .vl-funnel__actions {
  display: flex;
  align-items: center;
  gap: 24px;
  margin-top: var(--bd-margin);
}
[data-design="b"] .vl-funnel__actions--submit {
  justify-content: space-between;
}
[data-design="b"] .vl-funnel__back {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
  padding: 8px 0;
  transition: color var(--bd-d-register) var(--bd-ease-register);
  min-height: 44px;
  display: flex;
  align-items: center;
}
[data-design="b"] .vl-funnel__back:hover { color: var(--bd-ink); }
[data-design="b"] .vl-cta--submit {
  font-size: 16px;
  padding: 14px 24px;
}

/* Done state */
[data-design="b"] .vl-funnel__done {
  display: none;
  text-align: center;
  padding: clamp(28px,5vw,56px);
}
[data-design="b"] .vl-funnel__done.is-active { display: block; }
[data-design="b"] .vl-funnel__seal {
  width: 92px;
  height: 92px;
  margin: 0 auto 24px;
  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: 28px;
  font-weight: 500;
  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);
  animation: b-seal-press 600ms var(--bd-ease-unfurl) forwards;
}
[data-design="b"] .vl-funnel__done h3 {
  font-family: var(--bd-display);
  font-size: clamp(22px,2.8vw,32px);
  color: var(--bd-ink);
  margin-bottom: var(--bd-margin);
}
[data-design="b"] .vl-funnel__done p {
  font-size: 16px;
  color: var(--bd-ink-mute);
  line-height: 1.6;
}
[data-design="b"] .vl-funnel__done a {
  color: var(--bd-vermillion);
  text-decoration: underline;
  text-underline-offset: 3px;
}
@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-section__below {
  max-width: 720px;
  margin: 40px auto 0;
  text-align: center;
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
}


/* ═══════════════════════════════════════════════════════════════════════
   ELEMENT 4 — Ambient segment B — Portfolio ledger (mid-page)
   ═══════════════════════════════════════════════════════════════════════ */
[data-design="b"] .vl-portfolio {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-portfolio__head {
  max-width: 900px;
  margin: 0 auto var(--bd-chapter);
}
[data-design="b"] .vl-portfolio__head h2 {
  font-family: var(--bd-display);
  font-size: clamp(36px,5.2vw,64px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-margin);
}
[data-design="b"] .vl-portfolio__note {
  font-size: clamp(16px,1.4vw,19px);
  color: var(--bd-ink-mute);
  max-width: 60ch;
}
[data-design="b"] .vl-ledger {
  max-width: 1100px;
  margin: 0 auto;
}
[data-design="b"] .vl-ledger__row {
  display: grid;
  grid-template-columns: 80px 1fr 200px 140px;
  gap: 24px;
  align-items: start;
  padding: 32px 0;
  position: relative;
  border-bottom: 1px solid var(--bd-rule-faint);
}
[data-design="b"] .vl-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"] .vl-ledger__row[data-in="true"]::after { width: 100%; }
[data-design="b"] .vl-ledger__row::before {
  content: "";
  position: absolute;
  left: -18px; 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"] .vl-ledger__row[data-in="true"]::before { transform: scale(1); }

[data-design="b"] .vl-ledger__num {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-ink-mute);
  padding-top: 4px;
}
[data-design="b"] .vl-ledger__title {
  font-family: var(--bd-display);
  font-size: clamp(20px,2.2vw,28px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-snug);
}
[data-design="b"] .vl-ledger__desc {
  font-size: clamp(15px,1.3vw,17px);
  color: var(--bd-ink-soft);
  line-height: 1.6;
  max-width: 52ch;
}
[data-design="b"] .vl-ledger__type {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bd-vermillion);
  padding-top: 6px;
}
[data-design="b"] .vl-ledger__yr {
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .18em;
  color: var(--bd-ink-mute);
  padding-top: 6px;
}
@media (max-width: 760px) {
  [data-design="b"] .vl-ledger__row {
    grid-template-columns: 60px 1fr;
    row-gap: 8px;
  }
  [data-design="b"] .vl-ledger__type,
  [data-design="b"] .vl-ledger__yr {
    grid-column: 2;
    text-align: left;
  }
}
[data-design="b"] .vl-portfolio__repeat-cta {
  max-width: 1100px;
  margin: clamp(48px,6vw,80px) auto 0;
  display: flex;
  justify-content: flex-start;
}

/* Services (also uses ledger row animation) */
[data-design="b"] .vl-services {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-services__head {
  max-width: 900px;
  margin: 0 auto var(--bd-chapter);
}
[data-design="b"] .vl-services__head h2 {
  font-family: var(--bd-display);
  font-size: clamp(36px,5.2vw,64px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-margin);
}
[data-design="b"] .vl-services__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
}
[data-design="b"] .vl-service-card {
  padding: clamp(24px,3vw,36px);
  background: var(--bd-parchment);
  border: 1px solid var(--bd-rule-faint);
  position: relative;
  overflow: hidden;
}
[data-design="b"] .vl-service-card::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 2px; width: 0;
  background: var(--bd-vermillion);
  transition: width 900ms var(--bd-ease-settle);
}
[data-design="b"] .vl-service-card[data-in="true"]::after { width: 100%; }
[data-design="b"] .vl-service-card::before {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 2px; width: 0;
  background: transparent;
}
[data-design="b"] .vl-service-card h3 {
  font-family: var(--bd-display);
  font-size: clamp(18px,2vw,24px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-snug);
}
[data-design="b"] .vl-service-card p {
  font-size: clamp(15px,1.3vw,17px);
  color: var(--bd-ink-soft);
  line-height: 1.6;
}

/* Process (Element 4 mid-page ambient — phase illumination) */
[data-design="b"] .vl-process {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-process__head {
  max-width: 900px;
  margin: 0 auto var(--bd-chapter);
}
[data-design="b"] .vl-process__head h2 {
  font-family: var(--bd-display);
  font-size: clamp(36px,5.2vw,64px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-margin);
}
[data-design="b"] .vl-process__phases {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 32px;
  max-width: 1100px;
  margin: 0 auto;
  counter-reset: phase;
}
[data-design="b"] .vl-process__phase {
  padding: clamp(24px,3vw,36px);
  background: var(--bd-parchment-deep);
  border: 1px solid var(--bd-rule-faint);
  border-top: 3px solid var(--bd-rule-faint);
  transition: border-top-color 600ms var(--bd-ease-settle);
}
[data-design="b"] .vl-process__phase[data-in="true"] {
  border-top-color: var(--bd-vermillion);
}
[data-design="b"] .vl-process__phase-num {
  display: block;
  font-family: var(--bd-mono);
  font-size: 11px;
  letter-spacing: .22em;
  color: var(--bd-ink-mute);
  margin-bottom: var(--bd-snug);
}
[data-design="b"] .vl-process__phase h3 {
  font-family: var(--bd-display);
  font-size: clamp(18px,2vw,22px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-snug);
}
[data-design="b"] .vl-process__phase p {
  font-size: clamp(15px,1.3vw,16px);
  color: var(--bd-ink-soft);
  line-height: 1.6;
}

/* About */
[data-design="b"] .vl-about {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-about__content {
  max-width: 720px;
  margin: 0 auto;
}
[data-design="b"] .vl-about__content h2 {
  font-family: var(--bd-display);
  font-size: clamp(28px,3.6vw,48px);
  font-weight: 500;
  color: var(--bd-ink);
  margin-bottom: var(--bd-bay);
}
[data-design="b"] .vl-about__content p {
  font-size: clamp(17px,1.5vw,20px);
  line-height: 1.64;
  color: var(--bd-ink-soft);
  margin-bottom: var(--bd-margin);
  max-width: 66ch;
}

/* Contact */
[data-design="b"] .vl-contact {
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px);
  border-bottom: 1px solid var(--bd-rule);
}
[data-design="b"] .vl-contact__content {
  max-width: 720px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
[data-design="b"] .vl-contact__content h2 {
  font-family: var(--bd-display);
  font-size: clamp(28px,3.6vw,48px);
  font-weight: 500;
  color: var(--bd-ink);
}
[data-design="b"] .vl-contact__content p {
  font-size: clamp(16px,1.4vw,18px);
  color: var(--bd-ink-mute);
  line-height: 1.6;
  max-width: 58ch;
}
[data-design="b"] .vl-contact__phone {
  font-family: var(--bd-display);
  font-size: clamp(26px,3vw,40px);
  font-weight: 500;
  color: var(--bd-vermillion);
  text-decoration: none;
  letter-spacing: .02em;
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-contact__phone:hover { color: var(--bd-vermillion-deep); }

/* Footer (Colophon) */
[data-design="b"] .vl-footer {
  background: var(--bd-ink);
  color: var(--bd-parchment-edge);
  border-top: 1px solid rgba(242,235,219,.12);
}
[data-design="b"] .vl-footer__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(48px,6vw,80px) clamp(20px,4vw,48px);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  align-items: start;
}
[data-design="b"] .vl-footer__name {
  display: block;
  font-family: var(--bd-display);
  font-size: 22px;
  font-weight: 500;
  color: var(--bd-parchment);
  margin-bottom: 6px;
}
[data-design="b"] .vl-footer__loc {
  font-family: var(--bd-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bd-foxing);
}
[data-design="b"] .vl-footer__links,
[data-design="b"] .vl-footer__contact {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
[data-design="b"] .vl-footer__links a,
[data-design="b"] .vl-footer__contact a {
  font-family: var(--bd-body);
  font-size: 15px;
  color: var(--bd-foxing);
  text-decoration: none;
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="b"] .vl-footer__links a:hover,
[data-design="b"] .vl-footer__contact a:hover {
  color: var(--bd-parchment);
}
[data-design="b"] .vl-footer__legal p {
  font-family: var(--bd-mono);
  font-size: 10px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bd-foxing);
  line-height: 1.7;
}
[data-design="b"] .vl-footer__copy { margin-top: 8px; }
@media (max-width: 768px) {
  [data-design="b"] .vl-footer__inner {
    grid-template-columns: 1fr 1fr;
  }
  [data-design="b"] .vl-footer__legal {
    grid-column: 1 / -1;
  }
}
@media (max-width: 480px) {
  [data-design="b"] .vl-footer__inner {
    grid-template-columns: 1fr;
  }
}

/* ─── prefers-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::before,
  [data-design="b"] .vl-hero__wash::after,
  [data-design="b"] .vl-hero__thread,
  [data-design="b"] .bp-h1,
  [data-design="b"] .bp-h2,
  [data-design="b"] .bp-h3,
  [data-design="b"] .bp-v1,
  [data-design="b"] .bp-v2,
  [data-design="b"] .bp-v3,
  [data-design="b"] .bp-arc,
  [data-design="b"] .bp-tick,
  [data-design="b"] .bp-reg,
  [data-design="b"] .bp-anno,
  [data-design="b"] .vl-pointer__rule,
  [data-design="b"] .vl-pointer__chevron,
  [data-design="b"] .vl-pointer__label { animation: none !important; opacity: 1 !important; transform: none !important; stroke-dashoffset: 0 !important; }
  [data-design="b"] .vl-cta { animation: none !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 { transition-duration: 200ms !important; }
  [data-design="b"] .vl-ledger__row::before { transition-duration: 200ms !important; }
  [data-design="b"] .vl-process__phase { transition-duration: 200ms !important; }
}


/* ═══════════════════════════════════════════════════════════════════════
   MOBILE / NO-H-SCROLL GUARDS
   All rules scoped to [data-design="b"].dq-design — never bare/global
   ═══════════════════════════════════════════════════════════════════════ */
[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;
}

@media (max-width: 480px) {
  [data-design="b"] .vl-hero__actions {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  [data-design="b"] .vl-cta {
    justify-content: center;
  }
  [data-design="b"] .vl-funnel__steps {
    min-height: 520px;
  }
  [data-design="b"] .vl-process__phases {
    grid-template-columns: 1fr;
  }
  [data-design="b"] .vl-services__grid {
    grid-template-columns: 1fr;
  }
}

/* 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; }
