/* ═══════════════════════════════════════════════════════
   Broadside design → slot a
   Slot-remapped: ALL selectors use [data-design="a"]
   Keyframes prefixed: broadside-a-
   All selectors scoped to .dq-design or [data-design="a"]
   ═══════════════════════════════════════════════════════ */

/* ── Google Fonts ──────────────────────────────────────── */
@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 ──────────────────────────────────────── */
[data-design="a"] {
  --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);

  --bd-display: 'EB Garamond', Georgia, serif;
  --bd-body:    'Spectral', Georgia, serif;
  --bd-mono:    'JetBrains Mono', 'Courier New', 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-none: 0;
  --bd-r-seal: 50%;
  --bd-r-leaf: 2px;

  /* primary color exposed per contract */
  --design-a-primary: #B33A2A;
}

/* ── Reset / Box model ─────────────────────────────────── */
[data-design="a"].dq-design,
[data-design="a"] .dq-design {
  max-width: 100%;
  overflow-x: clip;
}
[data-design="a"].dq-design * {
  min-width: 0;
  box-sizing: border-box;
}
[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) {
  max-width: 100%;
  height: auto;
}

[data-design="a"] {
  font-family: var(--bd-body);
  font-size: clamp(17px, 1.5vw, 20px);
  color: var(--bd-ink-soft);
  background: var(--bd-parchment);
  line-height: 1.6;
}

[data-design="a"] *, [data-design="a"] *::before, [data-design="a"] *::after {
  box-sizing: border-box;
}

[data-design="a"] h1, [data-design="a"] h2, [data-design="a"] h3,
[data-design="a"] h4, [data-design="a"] h5, [data-design="a"] h6 {
  font-family: var(--bd-display);
  font-weight: 500;
  color: var(--bd-ink);
  line-height: 1.08;
  margin: 0;
}

[data-design="a"] p { margin: 0; }
[data-design="a"] a { color: var(--bd-vermillion); }
[data-design="a"] a:hover { color: var(--bd-vermillion-deep); }
[data-design="a"] ul, [data-design="a"] ol { margin: 0; padding: 0; list-style: none; }
[data-design="a"] fieldset { border: none; margin: 0; padding: 0; }
[data-design="a"] legend { padding: 0; }
[data-design="a"] address { font-style: normal; }
[data-design="a"] button { cursor: pointer; }

/* ── Element 1 — Animated minimalist header ────────────── */
[data-design="a"] .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="a"] .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: broadside-a-header-wash 27s var(--bd-ease-settle) infinite alternate;
}
[data-design="a"] .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:
    broadside-a-header-rule-draw 1100ms 200ms var(--bd-ease-settle) forwards,
    broadside-a-header-rule-breath 31s 1500ms var(--bd-ease-settle) infinite;
}
@keyframes broadside-a-header-wash {
  0%,100% { opacity: .85; }
  50%     { opacity: 1; }
}
@keyframes broadside-a-header-rule-draw { to { transform: scaleX(1); } }
@keyframes broadside-a-header-rule-breath { 0%,100% { opacity: .9; } 50% { opacity: .55; } }

[data-design="a"] .vl-header__bar {
  position: relative; z-index: 2;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 clamp(16px, 4vw, 48px);
  height: 64px;
}

[data-design="a"] .vl-logo {
  text-decoration: none; display: flex; flex-direction: column; gap: 1px;
}
[data-design="a"] .vl-logo__mark {
  font-family: var(--bd-display); font-size: clamp(18px,2vw,22px); font-weight: 500;
  color: var(--bd-ink); letter-spacing: .01em;
}
[data-design="a"] .vl-logo__mark em { font-style: italic; color: var(--bd-vermillion); }
[data-design="a"] .vl-logo__seal {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--bd-ink-mute);
}
@media (max-width: 560px) {
  [data-design="a"] .vl-logo__seal { display: none; }
}

[data-design="a"] .vl-menu-btn {
  width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  background: transparent; border: 1px solid transparent; border-radius: var(--bd-r-none);
  transition: background var(--bd-d-register) var(--bd-ease-register),
              border-color var(--bd-d-register) var(--bd-ease-register);
  position: relative;
}
[data-design="a"] .vl-menu-btn:hover {
  background: var(--bd-parchment-deep); border-color: var(--bd-rule);
}
[data-design="a"] .vl-menu-btn span,
[data-design="a"] .vl-menu-btn span::before,
[data-design="a"] .vl-menu-btn span::after {
  display: block; width: 22px; height: 1.5px; background: var(--bd-ink);
  transition: transform var(--bd-d-settle) var(--bd-ease-settle),
              opacity var(--bd-d-register) var(--bd-ease-register);
}
[data-design="a"] .vl-menu-btn span {
  position: relative;
}
[data-design="a"] .vl-menu-btn span::before,
[data-design="a"] .vl-menu-btn span::after {
  content: ""; position: absolute; left: 0;
}
[data-design="a"] .vl-menu-btn span::before { top: -7px; }
[data-design="a"] .vl-menu-btn span::after  { top: 7px; }
[data-design="a"] .vl-menu-btn[aria-expanded="true"] span { background: transparent; }
[data-design="a"] .vl-menu-btn[aria-expanded="true"] span::before { transform: translateY(7px) rotate(45deg); }
[data-design="a"] .vl-menu-btn[aria-expanded="true"] span::after  { transform: translateY(-7px) rotate(-45deg); }

/* ── Drawer ──────────────────────────────────────────────── */
[data-design="a"] .vl-drawer {
  position: fixed; inset: 0; z-index: 39;
  background: var(--bd-parchment);
  border-right: 1px solid var(--bd-rule);
  padding: 80px clamp(24px,5vw,64px) 48px;
  display: flex; flex-direction: column; gap: var(--bd-stanza);
  transform: translateX(-100%);
  transition: transform var(--bd-d-unfurl) var(--bd-ease-unfurl);
  max-width: 360px; width: 90%;
  overflow-y: auto;
}
[data-design="a"] .vl-drawer[data-open="true"] { transform: translateX(0); }
[data-design="a"] .vl-drawer[hidden] { display: none; }

[data-design="a"] .vl-drawer__inner {
  display: flex; flex-direction: column; gap: var(--bd-bay);
}
[data-design="a"] .vl-drawer nav {
  display: flex; flex-direction: column; gap: var(--bd-gutter);
}
[data-design="a"] .vl-drawer nav a {
  font-family: var(--bd-display); font-size: 22px; font-weight: 500;
  color: var(--bd-ink); text-decoration: none; letter-spacing: .01em;
  transition: transform var(--bd-d-register) var(--bd-ease-settle),
              color var(--bd-d-register) var(--bd-ease-register);
  display: flex; align-items: baseline; justify-content: space-between;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .vl-drawer nav a:hover {
    transform: translateX(4px); color: var(--bd-vermillion-deep);
  }
}
[data-design="a"] .vl-drawer nav a small {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .2em; color: var(--bd-ink-mute);
}
[data-design="a"] .vl-drawer__ctas {
  display: flex; flex-direction: column; gap: var(--bd-gutter);
}

/* ── Element 2 — CTA (wax-seal-press) ─────────────────── */
[data-design="a"] .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: broadside-a-cta-breath 5.2s var(--bd-ease-settle) infinite;
  min-height: 44px;
}
[data-design="a"] .vl-cta:hover {
  background: var(--bd-vermillion-deep);
  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);
  color: #F8EFE0;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .vl-cta:hover { transform: translateY(-1px); }
}
[data-design="a"] .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="a"] .vl-cta:focus-visible { outline: 2px solid var(--bd-ink); outline-offset: 3px; }
[data-design="a"] .vl-cta__arrow::after { content: "→"; }
[data-design="a"] .vl-cta--ghost {
  background: transparent; color: var(--bd-ink); border-color: var(--bd-rule);
  animation: none;
  box-shadow: none;
}
[data-design="a"] .vl-cta--ghost:hover {
  background: var(--bd-parchment-deep); color: var(--bd-ink);
}
[data-design="a"] .vl-cta--submit {
  border: none;
}
@keyframes broadside-a-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 with Ken-Burns unique animated backdrop ── */
[data-design="a"] .vl-hero {
  position: relative; isolation: isolate; overflow: hidden;
  padding: clamp(64px,9vw,120px) clamp(20px,4vw,48px) clamp(80px,11vw,140px);
  border-bottom: 1px solid var(--bd-rule);
  background: var(--bd-ink); /* fallback if image fails */
  min-height: 65vh;
}

/* Ken-Burns unique animated backdrop */
[data-design="a"] .vl-hero__kb {
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
[data-design="a"] .vl-hero__kb-img {
  position: absolute; inset: -5%; width: 110%; height: 110%;
  object-fit: cover; object-position: center;
  max-width: none; /* override reset — this is an abs-positioned hero bg */
  animation: broadside-a-hero-kb 23s var(--bd-ease-settle) infinite alternate;
  will-change: transform;
}
@keyframes broadside-a-hero-kb {
  0%   { transform: scale(1) translate(0,0); }
  100% { transform: scale(1.06) translate(-2%, 1%); }
}
[data-design="a"] .vl-hero__kb-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(26,22,18,.82) 0%, rgba(26,22,18,.62) 40%, rgba(26,22,18,.78) 100%);
}

/* Ink-wash substrate (E3 base layer behind text) */
[data-design="a"] .vl-hero__wash {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
}
[data-design="a"] .vl-hero__wash::before,
[data-design="a"] .vl-hero__wash::after {
  content: ""; position: absolute; inset: -10%;
  filter: blur(6px); mix-blend-mode: screen;
}
[data-design="a"] .vl-hero__wash::before {
  background:
    radial-gradient(45% 35% at 25% 38%, rgba(179,58,42,.28), transparent 62%),
    radial-gradient(50% 40% at 78% 62%, rgba(166,134,74,.22), transparent 60%);
  animation: broadside-a-hero-wash-a 31s var(--bd-ease-settle) infinite alternate;
}
[data-design="a"] .vl-hero__wash::after {
  background:
    radial-gradient(60% 50% at 70% 25%, rgba(26,22,18,.12), transparent 60%),
    radial-gradient(40% 40% at 18% 80%, rgba(179,58,42,.16), transparent 65%);
  animation: broadside-a-hero-wash-b 23s var(--bd-ease-settle) infinite alternate;
}
@keyframes broadside-a-hero-wash-a {
  0%   { transform: translate3d(0,0,0) scale(1); opacity: .85; }
  100% { transform: translate3d(-3%,2%,0) scale(1.04); opacity: 1; }
}
@keyframes broadside-a-hero-wash-b {
  0%   { transform: translate3d(0,0,0) scale(1); opacity: .80; }
  100% { transform: translate3d(2%,-2%,0) scale(1.05); opacity: 1; }
}
[data-design="a"] .vl-hero__thread {
  position: absolute; left: 0; right: 0; bottom: 0; height: 1px; z-index: 2;
  background: linear-gradient(90deg, transparent 10%, var(--bd-vermillion) 50%, transparent 90%);
  transform: scaleX(0); transform-origin: center;
  animation: broadside-a-hero-thread-draw 1600ms 350ms var(--bd-ease-settle) forwards;
}
@keyframes broadside-a-hero-thread-draw { to { transform: scaleX(1); } }

[data-design="a"] .vl-hero__inner {
  position: relative; z-index: 3;
  display: grid;
  grid-template-columns: 1fr min(360px, 38%);
  gap: clamp(32px, 5vw, 80px);
  max-width: 1200px; margin: 0 auto;
  align-items: start;
}
@media (max-width: 880px) {
  [data-design="a"] .vl-hero__inner { grid-template-columns: 1fr; }
  [data-design="a"] .vl-hero__side { display: none; }
}

[data-design="a"] .vl-hero__content {
  display: flex; flex-direction: column; gap: clamp(16px, 2vw, 24px);
}

[data-design="a"] .vl-eyebrow {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(248,239,224,.7);
  /* opacity:1 at first paint — not reveal-gated */
}

[data-design="a"] .vl-hero__title {
  font-family: var(--bd-display); font-size: clamp(36px, 5.5vw, 72px);
  font-weight: 500; line-height: 1.04; letter-spacing: -.012em;
  color: #F2EBDB;
  /* opacity:1 at first paint */
}

[data-design="a"] .vl-hero__lede {
  font-family: var(--bd-display); font-style: italic;
  font-size: clamp(18px, 2vw, 24px); color: rgba(242,235,219,.85);
  line-height: 1.45; max-width: 52ch;
  /* opacity:1 at first paint */
}

[data-design="a"] .vl-hero__meta {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(248,239,224,.55);
  /* opacity:1 at first paint */
}

[data-design="a"] .vl-hero__actions {
  display: flex; align-items: center; gap: var(--bd-gutter); flex-wrap: wrap;
  padding-top: var(--bd-snug);
}

[data-design="a"] .vl-hero__side {
  background: rgba(26,22,18,.45); border: 1px solid rgba(242,235,219,.15);
  padding: var(--bd-gutter);
  display: grid; grid-template-columns: auto 1fr; gap: 8px var(--bd-gutter);
  align-items: baseline;
}
[data-design="a"] .vl-hero__side dt {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .16em;
  text-transform: uppercase; color: var(--bd-vermillion);
  grid-column: 1;
}
[data-design="a"] .vl-hero__side dd {
  font-family: var(--bd-body); font-size: 14px; color: rgba(242,235,219,.75);
  margin: 0; grid-column: 2;
}

/* ── Element 6 — Pointer (dimension-line / drafted-measured) ── */
[data-design="a"] .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;
  /* Wrapper must be visibly rendered — opacity:1, height > 8px */
  opacity: 1;
  min-height: 180px;
}
[data-design="a"] .vl-pointer__inner {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  pointer-events: auto;
  padding: 24px 0;
}
[data-design="a"] .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:
    broadside-a-pointer-draw 1400ms 1100ms var(--bd-ease-settle) both,
    broadside-a-pointer-breath 5.4s 2500ms var(--bd-ease-settle) infinite;
  /* Ensure rule is visible — never opacity:0 at rest */
}
[data-design="a"] .vl-pointer__chevron {
  width: 28px; height: 18px; color: var(--bd-vermillion-deep);
  /* initial state: draw-in animation — uses forwards fill to stay visible */
  opacity: 1;
  animation: broadside-a-pointer-glyph-breath 5.4s 2500ms var(--bd-ease-settle) infinite;
}
[data-design="a"] .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: 1;
  animation: broadside-a-pointer-label-in 900ms 2200ms var(--bd-ease-settle) forwards;
}
@keyframes broadside-a-pointer-draw { from { transform: scaleY(0); } to { transform: scaleY(1); } }
@keyframes broadside-a-pointer-breath { 0%,100% { opacity: 1; } 50% { opacity: .55; } }
@keyframes broadside-a-pointer-glyph-breath {
  0%   { opacity: 1; transform: translateY(-2px); }
  20%,100% { opacity: 1; transform: translateY(0); }
  60%  { opacity: .55; transform: translateY(2px); }
}
@keyframes broadside-a-pointer-label-in { from { opacity: .4; } to { opacity: 1; } }

/* ── Element 5 — Funnel (tipped-in pages) ─────────────── */
[data-design="a"] .vl-funnel-section {
  padding: var(--bd-chapter) clamp(20px,4vw,48px);
  background: var(--bd-parchment); border-bottom: 1px solid var(--bd-rule);
}
[data-design="a"] .vl-funnel-section__head {
  max-width: 720px; margin: 0 auto var(--bd-bay);
  text-align: center;
}
[data-design="a"] .vl-funnel-section__head h2 {
  font-size: clamp(28px,4vw,48px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-funnel-section__head p {
  font-style: italic; color: var(--bd-ink-mute); font-size: clamp(16px,1.4vw,20px);
}
[data-design="a"] .vl-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="a"] .vl-funnel__progress {
  display: flex; align-items: center; gap: var(--bd-gutter);
  padding: 16px clamp(20px,4vw,48px); border-bottom: 1px solid var(--bd-rule-faint);
}
[data-design="a"] .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; flex-shrink: 0;
}
[data-design="a"] .vl-funnel__progress-track {
  flex: 1; height: 2px; background: var(--bd-rule-faint); position: relative; overflow: hidden;
}
[data-design="a"] .vl-funnel__progress-bar {
  display: block; position: absolute; left: 0; top: 0; bottom: 0;
  background: var(--bd-vermillion); width: 100%;
  transform: scaleX(var(--bd-fn-ratio, 0)); transform-origin: left center;
  transition: transform var(--bd-d-settle) var(--bd-ease-settle);
}
[data-design="a"] .vl-funnel__steps {
  position: relative; padding: clamp(28px,5vw,56px);
  min-height: 400px; overflow: hidden;
}
[data-design="a"] .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="a"] .vl-funnel__step[data-active="true"] {
  opacity: 1; pointer-events: auto; transform: translateY(0) rotate(0);
  position: relative; inset: auto;
}
[data-design="a"] .vl-funnel__step h3 {
  font-size: clamp(20px,2.5vw,28px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-funnel__help {
  font-style: italic; color: var(--bd-ink-mute); font-size: 15px; margin-bottom: var(--bd-bay);
}
[data-design="a"] .vl-funnel__options {
  display: flex; flex-direction: column; gap: var(--bd-snug);
  margin-bottom: var(--bd-gutter);
}
[data-design="a"] .vl-funnel__opt {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; background: var(--bd-parchment);
  border: 1px solid var(--bd-rule-faint); cursor: pointer;
  font-family: var(--bd-body); font-size: 17px; color: var(--bd-ink-soft);
  text-align: left; transition:
    transform var(--bd-d-register) var(--bd-ease-settle),
    background var(--bd-d-register) var(--bd-ease-register),
    border-color var(--bd-d-register) var(--bd-ease-register);
  min-height: 44px;
}
[data-design="a"] .vl-funnel__opt::after {
  content: "→"; color: var(--bd-vermillion); opacity: 0;
  transition: opacity var(--bd-d-register) var(--bd-ease-register),
              transform var(--bd-d-register) var(--bd-ease-register);
  transform: translateX(-4px);
}
@media (hover: hover) and (pointer: fine) {
  [data-design="a"] .vl-funnel__opt:hover {
    transform: translateX(4px); background: var(--bd-parchment-deep);
    border-color: var(--bd-vermillion);
  }
  [data-design="a"] .vl-funnel__opt:hover::after { opacity: 1; transform: translateX(0); }
}
[data-design="a"] .vl-funnel__opt:focus-visible { outline: 2px solid var(--bd-vermillion); outline-offset: 2px; }
[data-design="a"] .vl-funnel__actions {
  display: flex; align-items: center; gap: var(--bd-gutter); padding-top: var(--bd-gutter);
  border-top: 1px solid var(--bd-rule-faint); margin-top: var(--bd-gutter);
}
[data-design="a"] .vl-funnel__actions--submit { justify-content: space-between; }
[data-design="a"] .vl-funnel__back {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--bd-ink-mute); background: none; border: none; cursor: pointer; padding: 0;
  min-height: 44px; min-width: 44px;
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="a"] .vl-funnel__back:hover { color: var(--bd-vermillion-deep); }
[data-design="a"] .vl-funnel__fields {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--bd-gutter); margin-bottom: var(--bd-gutter);
}
@media (max-width: 560px) {
  [data-design="a"] .vl-funnel__fields { grid-template-columns: 1fr; }
}
[data-design="a"] .vl-funnel__field {
  display: flex; flex-direction: column; gap: 6px;
}
[data-design="a"] .vl-funnel__field--full { grid-column: 1 / -1; }
[data-design="a"] .vl-funnel__field span {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--bd-ink-mute);
}
[data-design="a"] .vl-funnel__field em { font-style: italic; text-transform: none; letter-spacing: 0; }
[data-design="a"] .vl-funnel__field input,
[data-design="a"] .vl-funnel__field textarea {
  background: var(--bd-parchment); border: none; border-bottom: 1px solid var(--bd-ink);
  padding: 10px 0; font-family: var(--bd-body); font-size: 17px; color: var(--bd-ink);
  outline: none; width: 100%;
  transition: border-color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="a"] .vl-funnel__field input:focus,
[data-design="a"] .vl-funnel__field textarea:focus { border-bottom-color: var(--bd-vermillion); }
[data-design="a"] .vl-funnel__field textarea { resize: vertical; min-height: 80px; }

/* Confirmation state */
[data-design="a"] .vl-funnel__done { text-align: center; padding: var(--bd-bay) 0; }
[data-design="a"] .vl-funnel__done h3 {
  font-size: clamp(22px,3vw,32px); margin-bottom: var(--bd-gutter);
}
[data-design="a"] .vl-funnel__done p {
  font-style: italic; color: var(--bd-ink-mute); max-width: 40ch; margin: 0 auto;
}
[data-design="a"] .vl-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: 38px;
  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.95) rotate(-12deg); opacity: 0;
  animation: broadside-a-seal-press 600ms var(--bd-ease-unfurl) forwards;
}
@keyframes broadside-a-seal-press {
  0%   { transform: scale(0.95) rotate(-12deg); opacity: 0; }
  60%  { transform: scale(1.15) rotate(2deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}

[data-design="a"] .vl-funnel-section__trust {
  max-width: 720px; margin: var(--bd-gutter) auto 0;
  text-align: center;
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--bd-ink-mute); line-height: 2;
}
[data-design="a"] .vl-funnel-section__trust a { color: var(--bd-ink-mute); }
[data-design="a"] .vl-funnel-section__trust a:hover { color: var(--bd-vermillion); }

/* ── Portfolio ─────────────────────────────────────────── */
[data-design="a"] .vl-portfolio {
  padding: var(--bd-chapter) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep); border-bottom: 1px solid var(--bd-rule);
}
[data-design="a"] .vl-portfolio__head {
  max-width: 1200px; margin: 0 auto var(--bd-chapter);
}
[data-design="a"] .vl-portfolio__head h2 {
  font-size: clamp(28px,4vw,48px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-portfolio__head p {
  font-style: italic; color: var(--bd-ink-mute); font-size: clamp(15px,1.4vw,18px);
}
[data-design="a"] .vl-portfolio__entry {
  max-width: 1200px; margin: 0 auto var(--bd-chapter);
  display: grid; grid-template-columns: 1fr 1fr;
  gap: clamp(32px,5vw,80px); align-items: start;
}
[data-design="a"] .vl-portfolio__entry--reversed { direction: rtl; }
[data-design="a"] .vl-portfolio__entry--reversed > * { direction: ltr; }
@media (max-width: 768px) {
  [data-design="a"] .vl-portfolio__entry { grid-template-columns: 1fr; }
  [data-design="a"] .vl-portfolio__entry--reversed { direction: ltr; }
}
[data-design="a"] .vl-portfolio__photos--trio,
[data-design="a"] .vl-portfolio__photos--pair,
[data-design="a"] .vl-portfolio__photos--single {
  display: grid; gap: 8px;
}
[data-design="a"] .vl-portfolio__photos--trio { grid-template-columns: 1fr 1fr 1fr; }
[data-design="a"] .vl-portfolio__photos--pair { grid-template-columns: 1fr 1fr; }
[data-design="a"] .vl-portfolio__photos--single { grid-template-columns: 1fr; }
[data-design="a"] .vl-portfolio__photos figure { margin: 0; }
[data-design="a"] .vl-portfolio__photos img {
  display: block; width: 100%; height: 200px; object-fit: cover;
  border-radius: var(--bd-r-leaf);
}
[data-design="a"] .vl-portfolio__photos--single img { height: 320px; }
[data-design="a"] .vl-portfolio__photos figcaption {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .16em; text-transform: uppercase;
  color: var(--bd-ink-mute); margin-top: 6px; line-height: 1.4;
}
[data-design="a"] .vl-portfolio__copy {
  display: flex; flex-direction: column; gap: var(--bd-margin);
}
[data-design="a"] .vl-portfolio__copy h3 {
  font-size: clamp(22px,2.5vw,32px); border-bottom: 1px solid var(--bd-rule-faint);
  padding-bottom: var(--bd-snug);
}
[data-design="a"] .vl-portfolio__copy p {
  font-size: clamp(15px,1.4vw,18px); color: var(--bd-ink-soft); line-height: 1.65; max-width: 55ch;
}
[data-design="a"] .vl-portfolio__provenance {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--bd-foxing); border-left: 2px solid var(--bd-foxing); padding-left: 10px;
}
[data-design="a"] .vl-portfolio__cta {
  max-width: 1200px; margin: 0 auto; text-align: center;
  border-top: 1px solid var(--bd-rule-faint); padding-top: var(--bd-chapter);
}
[data-design="a"] .vl-portfolio__cta p {
  font-style: italic; color: var(--bd-ink-mute); margin-bottom: var(--bd-gutter);
}

/* ── Element 4 — Process (mid-page ambient — phase markers) ── */
[data-design="a"] .vl-process {
  padding: var(--bd-chapter) clamp(20px,4vw,48px);
  background: var(--bd-parchment); border-bottom: 1px solid var(--bd-rule);
}
[data-design="a"] .vl-process__head {
  max-width: 1200px; margin: 0 auto var(--bd-bay);
}
[data-design="a"] .vl-process__head h2 {
  font-size: clamp(26px,3.5vw,44px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-process__head p {
  font-style: italic; color: var(--bd-ink-mute);
}
[data-design="a"] .vl-process__steps {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(24px,4vw,64px);
}
[data-design="a"] .vl-process__step {
  display: flex; flex-direction: column; gap: var(--bd-snug);
  position: relative; padding-top: var(--bd-margin);
  opacity: 0; transform: translateY(20px);
  transition: opacity 600ms var(--bd-ease-settle), transform 600ms var(--bd-ease-settle);
}
[data-design="a"] .vl-process__step[data-phase-in="true"] {
  opacity: 1; transform: translateY(0);
}
[data-design="a"] .vl-process__step::before {
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--bd-rule-faint);
}
[data-design="a"] .vl-process__step[data-phase-in="true"]::before {
  background: linear-gradient(90deg, var(--bd-vermillion), var(--bd-parchment-edge));
}
[data-design="a"] .vl-process__num {
  font-family: var(--bd-mono); font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--bd-vermillion);
}
[data-design="a"] .vl-process__step h3 { font-size: clamp(18px,2vw,22px); margin-bottom: 4px; }
[data-design="a"] .vl-process__step p { font-size: 15px; color: var(--bd-ink-mute); line-height: 1.6; }

/* ── Services ──────────────────────────────────────────── */
[data-design="a"] .vl-services {
  padding: var(--bd-chapter) clamp(20px,4vw,48px);
  background: var(--bd-parchment-deep); border-bottom: 1px solid var(--bd-rule);
}
[data-design="a"] .vl-services__head {
  max-width: 1200px; margin: 0 auto var(--bd-bay);
}
[data-design="a"] .vl-services__head h2 {
  font-size: clamp(26px,3.5vw,44px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-services__head p { font-style: italic; color: var(--bd-ink-mute); }
[data-design="a"] .vl-services__list {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: clamp(24px,3vw,40px);
}
[data-design="a"] .vl-services__list li {
  padding: var(--bd-gutter); background: var(--bd-parchment);
  border: 1px solid var(--bd-rule-faint); border-left: 3px solid var(--bd-vermillion);
}
[data-design="a"] .vl-services__list h3 {
  font-size: clamp(17px,1.8vw,22px); margin-bottom: var(--bd-snug);
}
[data-design="a"] .vl-services__list p {
  font-size: 15px; color: var(--bd-ink-mute); line-height: 1.65;
}

/* ── About ─────────────────────────────────────────────── */
[data-design="a"] .vl-about {
  padding: var(--bd-chapter) clamp(20px,4vw,48px);
  background: var(--bd-parchment); border-bottom: 1px solid var(--bd-rule);
}
[data-design="a"] .vl-about__inner {
  max-width: 840px; margin: 0 auto;
}
[data-design="a"] .vl-about h2 {
  font-size: clamp(26px,3.5vw,44px); margin-bottom: var(--bd-bay);
}
[data-design="a"] .vl-about__copy {
  display: flex; flex-direction: column; gap: var(--bd-margin);
}
[data-design="a"] .vl-about__copy p {
  font-size: clamp(16px,1.4vw,20px); color: var(--bd-ink-soft); line-height: 1.68; max-width: 62ch;
}
[data-design="a"] .vl-about__copy address {
  margin-top: var(--bd-margin); font-size: 16px; color: var(--bd-ink-mute); line-height: 2;
}
[data-design="a"] .vl-about__copy address a { color: var(--bd-vermillion); text-decoration: none; }
[data-design="a"] .vl-about__copy address a:hover { color: var(--bd-vermillion-deep); }

/* ── Footer ────────────────────────────────────────────── */
[data-design="a"] .vl-footer {
  background: var(--bd-ink); color: rgba(242,235,219,.75);
  padding: var(--bd-chapter) clamp(20px,4vw,48px) var(--bd-bay);
  border-top: 1px solid rgba(242,235,219,.1);
}
[data-design="a"] .vl-footer__inner {
  max-width: 1200px; margin: 0 auto;
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  gap: clamp(24px,4vw,64px) clamp(16px,3vw,48px);
}
@media (max-width: 760px) {
  [data-design="a"] .vl-footer__inner { grid-template-columns: 1fr; }
}
[data-design="a"] .vl-footer__brand {
  display: flex; flex-direction: column; gap: 4px;
}
[data-design="a"] .vl-footer__name {
  font-family: var(--bd-display); font-size: clamp(18px,2vw,22px); color: #F2EBDB; font-weight: 500;
}
[data-design="a"] .vl-footer__loc {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .18em; text-transform: uppercase;
  color: rgba(242,235,219,.4);
}
[data-design="a"] .vl-footer__links,
[data-design="a"] .vl-footer__contact {
  display: flex; flex-direction: column; gap: 10px;
}
[data-design="a"] .vl-footer__links a,
[data-design="a"] .vl-footer__contact a {
  font-size: 15px; color: rgba(242,235,219,.65); text-decoration: none;
  transition: color var(--bd-d-register) var(--bd-ease-register);
}
[data-design="a"] .vl-footer__links a:hover,
[data-design="a"] .vl-footer__contact a:hover { color: var(--bd-vermillion); }
[data-design="a"] .vl-footer__legal {
  grid-column: 1 / -1; border-top: 1px solid rgba(242,235,219,.1);
  padding-top: var(--bd-gutter); margin-top: var(--bd-stanza);
  display: flex; flex-wrap: wrap; gap: 8px var(--bd-bay);
}
[data-design="a"] .vl-footer__legal p {
  font-family: var(--bd-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(242,235,219,.35); line-height: 1.8;
}
[data-design="a"] .vl-footer__legal a { color: rgba(242,235,219,.35); }
[data-design="a"] .vl-footer__legal a:hover { color: var(--bd-vermillion); }

/* ── Mobile — viewport clip guards ────────────────────────
   All rules scoped to .dq-design per the anti-chrome-modal guard.
   ──────────────────────────────────────────────────────── */
[data-design="a"].dq-design { max-width: 100%; overflow-x: clip; }
[data-design="a"].dq-design * { min-width: 0; }
[data-design="a"].dq-design img,
[data-design="a"].dq-design svg:not([data-keep-size]) { max-width: 100%; height: auto; }

@media (max-width: 480px) {
  [data-design="a"] .vl-portfolio__photos--trio { grid-template-columns: 1fr; }
  [data-design="a"] .vl-portfolio__photos--pair { grid-template-columns: 1fr; }
  [data-design="a"] .vl-portfolio__photos img { height: 200px; }
  [data-design="a"] .vl-funnel__steps { min-height: 480px; }
}

/* ── Reduced motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .vl-header__wash,
  [data-design="a"] .vl-header__rule { animation: none !important; transform: none !important; opacity: 1 !important; }
  [data-design="a"] .vl-hero__kb-img { animation: none !important; transform: none !important; }
  [data-design="a"] .vl-hero__wash::before,
  [data-design="a"] .vl-hero__wash::after,
  [data-design="a"] .vl-hero__thread { animation: none !important; transform: none !important; opacity: 1 !important; }
  [data-design="a"] .vl-cta { animation: none !important; }
  [data-design="a"] .vl-pointer__rule,
  [data-design="a"] .vl-pointer__chevron,
  [data-design="a"] .vl-pointer__label { animation: none !important; opacity: 1 !important; transform: none !important; }
  [data-design="a"] .vl-funnel__step { transition-duration: 100ms !important; transform: none !important; }
  [data-design="a"] .vl-funnel__seal { animation: none !important; transform: none !important; opacity: 1 !important; }
  [data-design="a"] .vl-process__step { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
