/* ==========================================================================
   PLAZA FLOORING LLC — Design B — Punch List (scoped [data-design="b"])
   ========================================================================== */

[data-design="b"] {
  --design-b-primary: #A6271C;
  --pl-bond: #F5F2E9;
  --pl-canary: #EFE4BC;
  --pl-pink: #EAD3CB;
  --pl-paper: #FBF9F1;
  --pl-graphite: #26241E;
  --pl-carbon: #4B445A;
  --pl-stamp: #A6271C;
  --pl-violet: #453D77;
  --pl-white: #FBF9F1;
  --pl-critical: #7E1D12;
  --pl-close: #3E5A3B;

  --pl-tab: 4px;
  --pl-indent: 8px;
  --pl-line: 16px;
  --pl-entry: 24px;
  --pl-block: 40px;
  --pl-sheet: 64px;
  --pl-walkdown: 80px;
  --pl-closeout: 128px;

  background: var(--pl-bond);
  color: var(--pl-graphite);
  font-family: "Public Sans", "Helvetica Neue", Arial, sans-serif;
}

[data-design="b"] .dq-design,
article.dq-design[data-design="b"] {
  max-width: none;
}

/* ===================== 1. HEADER — the carbon ghost ===================== */

[data-design="b"] .pl-header {
  position: sticky; top: 0; z-index: 40; background: var(--pl-bond);
  border-bottom: 1px solid var(--pl-graphite);
}
[data-design="b"] .pl-header__bar {
  max-width: 1320px; margin-inline: auto; padding: 12px clamp(20px, 5vw, 48px);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  position: relative;
}
[data-design="b"] .pl-logo { text-decoration: none; position: relative; z-index: 2; }
[data-design="b"] .pl-logo__mark {
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: 1.25rem; color: var(--pl-graphite); letter-spacing: 0.01em;
  display: inline-block; max-width: 60vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* The atmospheric layer: the carbon duplicate, offset and breathing on 24s (H-3 slow cycle) */
[data-design="b"] .pl-header__carbon {
  position: absolute; left: clamp(20px, 5vw, 48px); top: 14px; z-index: 1;
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: 1.25rem; color: var(--pl-violet); pointer-events: none;
  transform: translate(3px, 3px); opacity: 0.10;
  animation: pl-carbon-breathe-b 24s ease-in-out infinite;
  max-width: 60vw; overflow: hidden; white-space: nowrap;
}
@keyframes pl-carbon-breathe-b {
  0%, 100% { transform: translate(3px, 3px); opacity: 0.10; }
  50%      { transform: translate(5px, 4px); opacity: 0.16; }
}
[data-design="b"] .pl-burger {
  width: 44px; height: 44px; background: none; border: 1px solid var(--pl-graphite);
  border-radius: 0; cursor: pointer; display: grid; place-content: center; gap: 5px; padding: 0;
}
[data-design="b"] .pl-burger__rule { width: 18px; height: 2px; background: var(--pl-graphite); display: block; }
[data-design="b"] .pl-burger:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-drawer { position: absolute; inset-inline: 0; top: 100%; }
[data-design="b"] .pl-drawer__sheet {
  background: var(--pl-canary); border-bottom: 1px solid var(--pl-graphite);
  box-shadow: 0 1px 0 var(--pl-graphite), 0 5px 0 -2px var(--pl-canary), 0 9px 0 -4px var(--pl-pink);
  padding: 24px clamp(20px, 5vw, 48px) 40px; display: grid; gap: 8px;
  transform-origin: top center; transform: translateY(-8px); opacity: 0;
  transition: transform 320ms cubic-bezier(0.25, 0.7, 0.2, 1), opacity 320ms cubic-bezier(0.25, 0.7, 0.2, 1);
}
[data-design="b"] .pl-drawer[data-open="true"] .pl-drawer__sheet { transform: translateY(0); opacity: 1; }
[data-design="b"] .pl-drawer[hidden] { display: none; }
[data-design="b"] .pl-clip {
  font-family: "Courier Prime", "Courier New", monospace; font-size: 1.06rem; color: var(--pl-graphite);
  text-decoration: none; padding: 10px 0; border-bottom: 1px solid var(--pl-graphite); display: block;
  min-height: 44px;
}
[data-design="b"] .pl-clip:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-drawer__ctas { margin-top: 16px; display: grid; gap: 8px; }
[data-design="b"] .pl-clip--funnel { border-bottom: 2px solid var(--pl-stamp); font-weight: 700; }
@media (max-width: 560px) {
  [data-design="b"] .pl-logo__mark, [data-design="b"] .pl-header__carbon {
    white-space: normal; max-width: 70vw; font-size: 1.05rem;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-header__carbon { animation: none; }
  [data-design="b"] .pl-drawer__sheet { transition: none; }
}

/* ===================== 2. CTA — the action field under the press ===================== */

[data-design="b"] .pl-cta {
  position: relative; display: inline-flex; align-items: center; gap: 12px;
  min-height: 56px; padding: 14px 28px; background: var(--pl-paper);
  border: 1px solid var(--pl-graphite); border-radius: 0; text-decoration: none;
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: 1.06rem; color: var(--pl-graphite);
  transition: transform 90ms cubic-bezier(0.4, 0, 0.6, 1);
}
[data-design="b"] .pl-cta::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 2px;
  background: var(--pl-stamp); transform-origin: left center;
  animation: pl-cta-ink-b 5s ease-in-out infinite;
}
@keyframes pl-cta-ink-b {
  0%, 100% { transform: scaleX(0.9); opacity: 0.75; }
  50%      { transform: scaleX(1);   opacity: 1; }
}
[data-design="b"] .pl-cta::before {
  content: ""; position: absolute; inset: 0; border: 1px solid var(--pl-stamp);
  transform: translate(4px, -4px); opacity: 0;
  transition: opacity 240ms cubic-bezier(0.2, 0.6, 0.3, 1), transform 240ms cubic-bezier(0.2, 0.6, 0.3, 1);
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .pl-cta:hover::before { opacity: 0.5; transform: translate(3px, -3px); }
}
[data-design="b"] .pl-cta:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 3px; }
[data-design="b"] .pl-cta:focus-visible::before { opacity: 0.5; transform: translate(3px, -3px); }
[data-design="b"] .pl-cta:active { transform: translateY(1px) scale(0.99); }
[data-design="b"] .pl-cta:active::after { transform: scaleX(1); opacity: 1; animation: none; }
[data-design="b"] .pl-cta__seal {
  width: 14px; height: 14px; border: 2px solid var(--pl-stamp); border-radius: 50%;
  opacity: 0.85; flex: none;
}
[data-design="b"] .pl-cta--repeat { margin-top: var(--pl-block); }
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-cta::after { animation: none; transform: scaleX(1); opacity: 1; }
  [data-design="b"] .pl-cta, [data-design="b"] .pl-cta::before { transition: none; }
}

/* ===================== 3. HERO — the cover sheet ===================== */

[data-design="b"] .pl-hero {
  position: relative; min-height: 86vh; background: var(--pl-bond);
  overflow: hidden; display: grid; align-items: center; padding-block: 128px 96px;
  isolation: isolate;
}
[data-design="b"] .pl-hero__substrate { position: absolute; inset: 0; z-index: 1; }
[data-design="b"] .pl-hero__copy2,
[data-design="b"] .pl-hero__copy3 {
  position: absolute; inset: 8% 6% 10% 5%; background: var(--pl-canary);
  border: 1px solid rgba(38, 36, 30, 0.35); opacity: 0.55;
  transform: rotate(-0.6deg) translateX(0);
}
[data-design="b"] .pl-hero__copy3 { background: var(--pl-pink); opacity: 0.4; transform: rotate(0.7deg) translateX(0); }
[data-design="b"] .pl-hero__copy2 { animation: pl-fan-2-b 12s ease-in-out infinite; }
[data-design="b"] .pl-hero__copy3 { animation: pl-fan-3-b 12s ease-in-out infinite; }
@keyframes pl-fan-2-b {
  0%, 100% { transform: rotate(-0.6deg) translateX(0);   opacity: 0.55; }
  50%      { transform: rotate(-1.1deg) translateX(-6px); opacity: 0.7; }
}
@keyframes pl-fan-3-b {
  0%, 100% { transform: rotate(0.7deg) translateX(0);   opacity: 0.4; }
  50%      { transform: rotate(1.2deg) translateX(6px); opacity: 0.55; }
}
[data-design="b"] .pl-hero__form {
  position: absolute; inset: 6% 5% 8% 4%; background: var(--pl-paper);
  border: 1px solid var(--pl-graphite);
}
[data-design="b"] .pl-hero__rule {
  position: absolute; left: 12%; right: 8%; height: 1px; background: var(--pl-graphite);
  top: calc(18% + var(--i) * 13%); opacity: 0.5;
  transform: scaleX(0); transform-origin: left center;
  animation: pl-rule-strike-b 260ms steps(12, end) forwards;
  animation-delay: calc(200ms + var(--i) * 160ms);
}
@keyframes pl-rule-strike-b { to { transform: scaleX(1); } }
[data-design="b"] .pl-hero__box {
  position: absolute; left: 7%; width: 18px; height: 18px;
  border: 2px solid var(--pl-graphite); top: calc(17% + var(--i) * 13%); opacity: 0;
  animation: pl-box-in-b 240ms cubic-bezier(0.2, 0.6, 0.3, 1) forwards;
  animation-delay: calc(400ms + var(--i) * 180ms);
}
@keyframes pl-box-in-b { from { opacity: 0; transform: scale(0.95); } to { opacity: 0.7; transform: scale(1); } }
[data-design="b"] .pl-hero__seal {
  position: absolute; right: 9%; top: 14%; width: clamp(96px, 14vw, 176px); aspect-ratio: 1;
  border: 3px solid var(--pl-stamp); border-radius: 50%; opacity: 0;
  transform: rotate(-4deg) scale(1.06);
  animation: pl-seal-settle-b 240ms cubic-bezier(0.2, 0.6, 0.3, 1) 1.4s forwards;
  display: grid; place-content: center;
}
[data-design="b"] .pl-hero__seal-inner {
  width: 72%; height: 0; border-top: 2px solid var(--pl-stamp);
  box-shadow: 0 -10px 0 var(--pl-stamp), 0 10px 0 var(--pl-stamp);
  justify-self: center; align-self: center; opacity: 0.9; display: block; margin: 0 auto;
}
@keyframes pl-seal-settle-b {
  from { opacity: 0;   transform: rotate(-4deg) scale(1.06); }
  to   { opacity: 0.85; transform: rotate(-2.5deg) scale(1); }
}
/* HERO TEXT Z-INDEX (HARD): text layer sits above every backdrop layer */
[data-design="b"] .pl-hero__content {
  position: relative; z-index: 5; max-width: 1320px; width: 100%;
  margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .pl-hero__headline {
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: clamp(1.9rem, 5vw, 3.05rem); line-height: 1.15; color: var(--pl-graphite);
  margin: 0 0 24px; max-width: 22ch; opacity: 1;
}
[data-design="b"] .pl-hero__subtitle {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.125rem; line-height: 1.6;
  color: var(--pl-graphite); margin: 0 0 16px; max-width: 55ch; opacity: 1;
}
[data-design="b"] .pl-hero__subtitle:empty, [data-design="b"] .pl-hero__proof:empty { display: none; }
[data-design="b"] .pl-hero__proof {
  font-family: "Courier Prime", "Courier New", monospace; font-size: 0.875rem; line-height: 1.6;
  color: var(--pl-carbon); margin: 0 0 40px; max-width: 72ch; opacity: 1;
  white-space: normal; overflow: visible; text-overflow: clip;
}
[data-design="b"] [data-mf-role="hero"] { position: relative; z-index: 5; }
@media (max-width: 560px) {
  [data-design="b"] .pl-hero { min-height: 92vh; padding-block: 96px 64px; }
  [data-design="b"] .pl-hero__seal { right: 6%; top: 10%; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-hero__copy2, [data-design="b"] .pl-hero__copy3 { animation: none; }
  [data-design="b"] .pl-hero__rule { animation: none; transform: scaleX(1); }
  [data-design="b"] .pl-hero__box { animation: none; opacity: 0.7; transform: scale(1); }
  [data-design="b"] .pl-hero__seal { animation: none; opacity: 0.85; transform: rotate(-2.5deg) scale(1); }
}

/* ===================== 6. POINTER — the walk-down line ===================== */

[data-design="b"] .pl-pointer {
  position: relative; display: grid; justify-items: center; gap: 8px;
  padding-block: 40px 24px; background: var(--pl-bond);
  opacity: 1; min-height: 88px;
}
[data-design="b"] .pl-pointer__line {
  width: 1px; height: 88px; background: var(--pl-graphite);
  transform-origin: top center; transform: scaleY(0);
  animation: pl-walkdown-b 5.5s cubic-bezier(0.2, 0.6, 0.3, 1) infinite;
}
@keyframes pl-walkdown-b {
  0%        { transform: scaleY(0); }
  22%, 88%  { transform: scaleY(1); }
  100%      { transform: scaleY(1); }
}
[data-design="b"] .pl-pointer__tick {
  position: absolute; width: 10px; height: 1.5px; background: var(--pl-graphite);
  top: calc(52px + var(--i) * 24px); left: calc(50% + 4px); opacity: 0;
  animation: pl-tick-ink-b 5.5s ease-out infinite;
  animation-delay: calc(0.9s + var(--i) * 0.5s);
}
@keyframes pl-tick-ink-b {
  0%, 8%    { opacity: 0; transform: translateX(-3px); }
  14%, 84%  { opacity: 0.7; transform: translateX(0); }
  92%, 100% { opacity: 0; transform: translateX(-3px); }
}
[data-design="b"] .pl-pointer__openbox {
  width: 16px; height: 16px; border: 2px solid var(--pl-stamp); opacity: 0;
  animation: pl-openbox-b 5.5s ease-out infinite; animation-delay: 2.6s;
}
@keyframes pl-openbox-b {
  0%, 4%    { opacity: 0; transform: scale(0.95); }
  12%, 86%  { opacity: 0.9; transform: scale(1); }
  94%, 100% { opacity: 0; transform: scale(0.95); }
}
[data-design="b"] .pl-pointer__label {
  font-family: "Courier Prime", "Courier New", monospace; font-size: 0.875rem;
  color: var(--pl-carbon); letter-spacing: 0.04em;
  white-space: nowrap; max-width: 16ch; overflow: hidden; text-overflow: ellipsis;
}
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-pointer__line { animation: none; transform: scaleY(1); }
  [data-design="b"] .pl-pointer__tick { animation: none; opacity: 0.7; transform: translateX(0); }
  [data-design="b"] .pl-pointer__openbox { animation: none; opacity: 0.9; transform: scale(1); }
}

/* ===================== 5. FUNNEL / ESTIMATOR — the Date-Stamp Press ===================== */

[data-design="b"] .pl-funnel { padding-block: var(--pl-walkdown, 80px); background: var(--pl-bond); }
[data-design="b"] .pl-funnel__col { max-width: 880px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
[data-design="b"] .pl-funnel__title {
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2.12rem); line-height: 1.2; color: var(--pl-graphite); margin: 0 0 16px;
}
/* live range readout — EST-4 payback, always visible, never covered */
[data-design="b"] .pl-funnel__range {
  border: 1px solid var(--pl-graphite); background: var(--pl-paper);
  padding: 16px 20px; margin: 0 0 8px; display: grid; gap: 4px;
}
[data-design="b"] .pl-funnel__range-label {
  font-family: "Public Sans", Arial, sans-serif; font-weight: 600; font-size: 0.75rem;
  text-transform: uppercase; letter-spacing: 0.09em; color: var(--pl-carbon);
}
[data-design="b"] .pl-funnel__range-value {
  font-family: "Courier Prime", monospace; font-weight: 700; font-size: 1.5rem; color: var(--pl-stamp);
}
[data-design="b"] .pl-funnel__sample {
  font-family: "Courier Prime", monospace; font-size: 0.8125rem; color: var(--pl-carbon);
  margin: 0 0 12px;
}
[data-design="b"] .pl-funnel__stepindicator {
  font-family: "Courier Prime", monospace; font-size: 0.875rem; color: var(--pl-stamp);
  margin: 0 0 32px; border-bottom: 1px solid var(--pl-graphite); padding-bottom: 12px;
}
/* EST-8 (HARD): exactly one step group visible; steps stack, never side by side, never overlapped by nav */
[data-design="b"] .pl-step {
  border: 1px solid var(--pl-graphite); padding: 40px clamp(20px, 4vw, 40px); margin: 0;
  background: var(--pl-paper);
  box-shadow: 0 1px 0 var(--pl-graphite), 0 5px 0 -2px var(--pl-canary), 0 9px 0 -4px var(--pl-pink);
  position: relative;
}
[data-design="b"] .pl-step[hidden] { display: none; }
[data-design="b"] .pl-step[data-sheet="canary"] { background: var(--pl-canary); }
[data-design="b"] .pl-step[data-sheet="pink"] { background: var(--pl-pink); }
[data-design="b"] .pl-step[data-entering] { animation: pl-feed-in-b 320ms cubic-bezier(0.25, 0.7, 0.2, 1); }
@keyframes pl-feed-in-b {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
[data-design="b"] .pl-step__q {
  font-family: "Courier Prime", monospace; font-weight: 700; font-size: 1.27rem;
  line-height: 1.3; color: var(--pl-graphite); padding: 0 0 24px; margin: 0;
}
[data-design="b"] .pl-step__items { display: grid; gap: 16px; }
[data-design="b"] .pl-item {
  position: relative; display: flex; align-items: center; gap: 16px; text-align: left;
  min-height: 56px; padding: 12px 64px 12px 12px; width: 100%;
  background: none; border: 0; border-bottom: 1px solid var(--pl-graphite);
  border-radius: 0; cursor: pointer;
  font-family: "Courier Prime", monospace; font-size: 1.06rem; color: var(--pl-graphite);
  transition: transform 90ms cubic-bezier(0.4, 0, 0.6, 1);
}
[data-design="b"] .pl-item::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -3px; height: 1px;
  background: var(--pl-graphite); opacity: 0; transition: opacity 120ms ease-out;
}
@media (hover: hover) and (pointer: fine) {
  [data-design="b"] .pl-item:hover::after { opacity: 1; }
}
[data-design="b"] .pl-item:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-item:focus-visible::after { opacity: 1; }
[data-design="b"] .pl-item:active { transform: translateY(1px) scale(0.995); }
[data-design="b"] .pl-item__box { width: 20px; height: 20px; border: 2px solid var(--pl-graphite); flex: none; position: relative; }
[data-design="b"] .pl-item__box::after {
  content: ""; position: absolute; inset: 2px; background: var(--pl-graphite); opacity: 0;
  clip-path: polygon(12% 52%, 26% 38%, 42% 58%, 76% 12%, 92% 26%, 44% 88%);
  transition: opacity 90ms ease-out;
}
[data-design="b"] .pl-item__label {
  white-space: normal; overflow: visible; max-width: none;
}
[data-design="b"] .pl-item__seal {
  position: absolute; right: 12px; top: 50%; width: 36px; height: 36px; margin-top: -18px;
  border: 2.5px solid var(--pl-stamp); border-radius: 50%; opacity: 0;
  transform: rotate(-6deg) scale(1.1);
}
[data-design="b"] .pl-item__seal::after {
  content: ""; position: absolute; left: 15%; right: 15%; top: 50%; height: 0;
  border-top: 2px solid var(--pl-stamp);
}
[data-design="b"] .pl-item[data-selected="true"] { color: var(--pl-graphite); }
[data-design="b"] .pl-item[data-selected="true"] .pl-item__box::after { opacity: 1; }
[data-design="b"] .pl-item[data-selected="true"] .pl-item__seal {
  animation: pl-seal-press-b 240ms cubic-bezier(0.2, 0.6, 0.3, 1) forwards;
}
@keyframes pl-seal-press-b {
  from { opacity: 0;    transform: rotate(-6deg) scale(1.1); }
  to   { opacity: 0.85; transform: rotate(-2.5deg) scale(1); }
}
[data-design="b"] .pl-contact { display: grid; gap: 24px; margin-bottom: 32px; }
[data-design="b"] .pl-contact__echo {
  font-family: "Courier Prime", monospace; font-size: 0.9375rem; color: var(--pl-graphite);
  background: var(--pl-paper); border: 1px solid var(--pl-graphite); padding: 12px 16px;
  margin: 0 0 24px;
}
[data-design="b"] .pl-contact__echo:empty { display: none; }
[data-design="b"] .pl-field { display: grid; gap: 4px; }
[data-design="b"] .pl-field__label {
  font-family: "Public Sans", Arial, sans-serif; font-weight: 600; font-size: 0.8125rem;
  text-transform: uppercase; letter-spacing: 0.09em; color: var(--pl-carbon);
}
[data-design="b"] .pl-field__input {
  font-family: "Courier Prime", monospace; font-size: 1.06rem; color: var(--pl-graphite);
  background: none; border: 0; border-bottom: 1px solid var(--pl-graphite); border-radius: 0;
  padding: 8px 0; width: 100%; transition: border-color 120ms ease-out;
}
[data-design="b"] .pl-field__input:focus { outline: none; border-bottom: 2px solid var(--pl-violet); }
[data-design="b"] .pl-funnel__submit {
  min-height: 56px; padding: 14px 28px; width: 100%;
  background: var(--pl-stamp); color: var(--pl-white); border: 1px solid var(--pl-graphite); border-radius: 0;
  font-family: "Courier Prime", monospace; font-weight: 700; font-size: 1.06rem; cursor: pointer;
  transition: transform 90ms cubic-bezier(0.4, 0, 0.6, 1);
}
[data-design="b"] .pl-funnel__submit:active { transform: translateY(1px) scale(0.995); }
[data-design="b"] .pl-funnel__submit:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 3px; }
/* nav sits BELOW the step sheet, in normal flow — never overlaps a chip (EST-8) */
[data-design="b"] .pl-funnel__nav { margin-top: 24px; }
[data-design="b"] .pl-funnel__back {
  background: none; border: 0; border-bottom: 1px solid var(--pl-carbon); border-radius: 0;
  font-family: "Courier Prime", monospace; font-size: 0.875rem; color: var(--pl-carbon);
  padding: 8px 0; cursor: pointer; min-height: 44px;
}
[data-design="b"] .pl-funnel__back:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-funnel__footnote {
  font-family: "Courier Prime", monospace; font-size: 0.875rem; line-height: 1.6;
  color: var(--pl-carbon); margin: 24px 0 0;
}
[data-design="b"] .pl-funnel__form[data-complete="true"] .pl-step--contact {
  animation: pl-closeout-b 240ms cubic-bezier(0.2, 0.6, 0.3, 1);
}
@keyframes pl-closeout-b { from { transform: scale(0.99); } to { transform: scale(1); } }
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-step[data-entering] { animation: none; }
  [data-design="b"] .pl-item, [data-design="b"] .pl-funnel__submit { transition: none; }
  [data-design="b"] .pl-item[data-selected="true"] .pl-item__seal {
    animation: none; opacity: 0.85; transform: rotate(-2.5deg) scale(1);
  }
  [data-design="b"] .pl-funnel__form[data-complete="true"] .pl-step--contact { animation: none; }
}

/* ===================== 7. SCROLL HANDOFF — turning to the next sheet ===================== */

[data-design="b"] .pl-handoff { padding-block: var(--pl-walkdown, 80px); background: var(--pl-bond); }
[data-design="b"] .pl-handoff__col { max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
[data-design="b"] .pl-handoff__title {
  position: relative; font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2.12rem); line-height: 1.2; color: var(--pl-graphite);
  margin: 0 0 24px; padding-left: 56px; max-width: 28ch;
}
[data-design="b"] .pl-handoff__seal {
  position: absolute; left: 0; top: 0; width: 40px; height: 40px;
  border: 2.5px solid var(--pl-stamp); border-radius: 50%; opacity: 0.85; transform: rotate(-2.5deg);
}
[data-design="b"] .pl-handoff__body {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.0625rem; line-height: 1.65;
  color: var(--pl-graphite); max-width: 65ch; margin: 0;
}
@supports (animation-timeline: view()) {
  [data-design="b"] .pl-hero__form {
    animation: pl-sheet-turn-top-b linear both;
    animation-timeline: view();
    animation-range: exit 0% exit 100%;
  }
  [data-design="b"] .pl-hero__copy2 {
    animation: pl-fan-2-b 12s ease-in-out infinite, pl-sheet-turn-mid-b linear both;
    animation-timeline: auto, view();
    animation-range: normal, exit 0% exit 100%;
  }
  [data-design="b"] .pl-hero__copy3 {
    animation: pl-fan-3-b 12s ease-in-out infinite, pl-sheet-turn-under-b linear both;
    animation-timeline: auto, view();
    animation-range: normal, exit 0% exit 100%;
  }
  [data-design="b"] .pl-handoff__title {
    animation: pl-title-stamp-b linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 60%;
    transform-origin: 0 100%;
  }
}
@keyframes pl-sheet-turn-top-b   { to { transform: translateY(-44px); opacity: 0.6; } }
@keyframes pl-sheet-turn-mid-b   { to { transform: rotate(-1.1deg) translateY(-18px); } }
@keyframes pl-sheet-turn-under-b { to { transform: rotate(1.2deg) translateY(-6px); } }
@keyframes pl-title-stamp-b {
  from { transform: rotate(1.2deg) translateY(14px); opacity: 0.15; }
  to   { transform: rotate(0deg) translateY(0); opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-hero__form,
  [data-design="b"] .pl-hero__copy2,
  [data-design="b"] .pl-hero__copy3,
  [data-design="b"] .pl-handoff__title { animation: none; }
}

/* ===================== 4. CLOSEOUT BOARD — process ===================== */

[data-design="b"] .pl-board {
  position: relative; padding-block: var(--pl-walkdown, 80px) calc(var(--pl-walkdown, 80px) + 24px);
  background: var(--pl-canary); border-block: 1px solid var(--pl-graphite);
}
[data-design="b"] .pl-board__col {
  position: relative; max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px);
}
[data-design="b"] .pl-board__title {
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2.12rem); line-height: 1.2; color: var(--pl-graphite);
  margin: 0 0 16px; border-bottom: 1px solid var(--pl-graphite); padding-bottom: 12px; max-width: 30ch;
}
[data-design="b"] .pl-board__intro {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.0625rem; line-height: 1.65;
  color: var(--pl-graphite); margin: 0 0 40px; max-width: 65ch;
}
[data-design="b"] .pl-board__items { list-style: none; margin: 0; padding: 0; display: grid; gap: 24px; counter-reset: pl-item-b; }
[data-design="b"] .pl-board__item {
  display: flex; align-items: flex-start; gap: 16px; padding-bottom: 16px;
  border-bottom: 1px solid rgba(38, 36, 30, 0.4); counter-increment: pl-item-b;
}
[data-design="b"] .pl-board__item::before {
  content: counter(pl-item-b, decimal-leading-zero); font-family: "Courier Prime", monospace;
  font-size: 0.875rem; color: var(--pl-carbon); padding-top: 3px;
}
[data-design="b"] .pl-board__check { width: 20px; height: 20px; border: 2px solid var(--pl-graphite); flex: none; margin-top: 2px; position: relative; }
[data-design="b"] .pl-board__check::after {
  content: ""; position: absolute; inset: 2px;
  background: var(--pl-close);
  clip-path: polygon(12% 52%, 26% 38%, 42% 58%, 76% 12%, 92% 26%, 44% 88%);
  opacity: 0;
}
[data-design="b"] .pl-board__label {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.0625rem; line-height: 1.55; color: var(--pl-graphite);
}
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(1) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 0s; }
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(2) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 1.6s; }
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(3) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 3.2s; }
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(4) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 4.8s; }
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(5) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 6.4s; }
[data-design="b"] .pl-board[data-live="true"] .pl-board__item:nth-child(6) .pl-board__check::after { animation: pl-close-tick-b 14s cubic-bezier(0.2, 0.6, 0.3, 1) infinite; animation-delay: 8s; }
@keyframes pl-close-tick-b {
  0%, 4%   { opacity: 0; transform: scale(0.95); }
  7%, 82%  { opacity: 1; transform: scale(1); }
  90%, 100% { opacity: 0; transform: scale(0.95); }
}
[data-design="b"] .pl-datestamp {
  position: relative; margin-top: 32px;
  width: 44px; height: 44px; border-radius: 50%; cursor: pointer;
  background: var(--pl-paper); border: 2px solid var(--pl-graphite);
  box-shadow: 0 3px 0 -1px var(--pl-graphite);
  transition: transform 90ms cubic-bezier(0.4, 0, 0.6, 1);
}
[data-design="b"] .pl-datestamp:active { transform: translateY(2px); }
[data-design="b"] .pl-datestamp:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-datestamp__mark {
  display: inline-block; margin-left: 16px; vertical-align: middle;
  font-family: "Courier Prime", monospace; font-size: 0.8rem; color: var(--pl-stamp);
  border: 1.5px solid var(--pl-stamp); padding: 2px 8px; pointer-events: none;
  opacity: 0; transform: rotate(-3deg) scale(1.06);
}
[data-design="b"] .pl-datestamp__mark[data-inked="true"] {
  animation: pl-date-ink-b 240ms cubic-bezier(0.2, 0.6, 0.3, 1) forwards;
}
@keyframes pl-date-ink-b {
  from { opacity: 0;   transform: rotate(-3deg) scale(1.06); }
  to   { opacity: 0.7; transform: rotate(-2deg) scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  [data-design="b"] .pl-board .pl-board__check::after { animation: none !important; opacity: 1; transform: scale(1); }
  [data-design="b"] .pl-datestamp { transition: none; }
  [data-design="b"] .pl-datestamp__mark[data-inked="true"] { animation: none; opacity: 0.7; transform: rotate(-2deg) scale(1); }
}

/* ===================== MATERIALS — the line-item schedule ===================== */

[data-design="b"] .pl-materials { padding-block: var(--pl-walkdown, 80px); background: var(--pl-bond); }
[data-design="b"] .pl-materials__col { max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
[data-design="b"] .pl-materials__title {
  font-family: "Courier Prime", "Courier New", monospace; font-weight: 700;
  font-size: clamp(1.5rem, 3vw, 2.12rem); line-height: 1.2; color: var(--pl-graphite);
  margin: 0 0 40px; border-bottom: 1px solid var(--pl-graphite); padding-bottom: 12px; max-width: 30ch;
}
[data-design="b"] .pl-materials__items { list-style: none; margin: 0 0 var(--pl-block); padding: 0; display: grid; gap: var(--pl-entry); max-width: 65ch; }
[data-design="b"] .pl-materials__item { display: flex; gap: 20px; padding-bottom: var(--pl-entry); border-bottom: 1px solid rgba(38, 36, 30, 0.4); }
[data-design="b"] .pl-materials__index {
  font-family: "Courier Prime", monospace; font-size: 0.9375rem; color: var(--pl-carbon); padding-top: 3px; flex: none;
}
[data-design="b"] .pl-materials__name {
  font-family: "Courier Prime", monospace; font-weight: 700; font-size: 1.1875rem; color: var(--pl-graphite); margin: 0 0 8px;
}
[data-design="b"] .pl-materials__desc {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.0625rem; line-height: 1.6; color: var(--pl-graphite); margin: 0;
}

/* ===================== ABOUT — the crew register ===================== */

[data-design="b"] .pl-about { padding-block: var(--pl-walkdown, 80px); background: var(--pl-canary); border-block: 1px solid var(--pl-graphite); }
[data-design="b"] .pl-about__col { max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
[data-design="b"] .pl-about__title {
  font-family: "Courier Prime", monospace; font-weight: 700; font-size: clamp(1.5rem, 3vw, 2.12rem);
  color: var(--pl-graphite); margin: 0 0 32px; border-bottom: 1px solid var(--pl-graphite); padding-bottom: 12px; max-width: 30ch;
}
[data-design="b"] .pl-about__block { max-width: 65ch; display: grid; gap: var(--pl-line); }
[data-design="b"] .pl-about__row {
  font-family: "Public Sans", Arial, sans-serif; font-size: 1.0625rem; line-height: 1.6; color: var(--pl-graphite);
  margin: 0; padding-bottom: var(--pl-line); border-bottom: 1px solid rgba(38, 36, 30, 0.4);
}
[data-design="b"] .pl-about__rowlabel {
  font-family: "Public Sans", Arial, sans-serif; font-weight: 600; font-size: 0.8125rem;
  text-transform: uppercase; letter-spacing: 0.09em; color: var(--pl-carbon); display: block; margin-bottom: 4px;
}

/* ===================== FOOTER — the form margin ===================== */

[data-design="b"] .pl-footer { padding-block: var(--pl-block) var(--pl-block); background: var(--pl-bond); border-top: 1px solid var(--pl-graphite); }
[data-design="b"] .pl-footer__col { max-width: 1320px; margin-inline: auto; padding-inline: clamp(20px, 5vw, 48px); }
[data-design="b"] .pl-footer__line {
  font-family: "Public Sans", Arial, sans-serif; font-size: 0.9375rem; color: var(--pl-graphite); margin: 0 0 8px;
}
[data-design="b"] .pl-footer__link { color: var(--pl-stamp); text-decoration: none; border-bottom: 1px solid var(--pl-stamp); }
[data-design="b"] .pl-footer__link:focus-visible { outline: 2px solid var(--pl-violet); outline-offset: 2px; }
[data-design="b"] .pl-footer__meta {
  font-family: "Courier Prime", monospace; font-size: 0.75rem; color: var(--pl-carbon); margin: 16px 0 0;
}

/* ==========================================================================
   MOBILE SAFETY + INTERIOR WRAPPER SELF-CENTER (appended per contract)
   ========================================================================== */

[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;}

[data-design="b"] .pl-header__bar,
[data-design="b"] .pl-hero__content,
[data-design="b"] .pl-funnel__col,
[data-design="b"] .pl-handoff__col,
[data-design="b"] .pl-board__col,
[data-design="b"] .pl-materials__col,
[data-design="b"] .pl-about__col,
[data-design="b"] .pl-footer__col {
  margin-inline: auto;
}

/* stranded-wrapper autofix (drain 2026-07-03): every fixed max-width column centers — gate content_uncentered_left_stranded */
[data-design="b"] .pl-hero__subtitle { margin-inline: auto; }
[data-design="b"] .pl-hero__proof { margin-inline: auto; }
[data-design="b"] .pl-handoff__title { margin-inline: auto; }
[data-design="b"] .pl-handoff__body { margin-inline: auto; }
[data-design="b"] .pl-board__title { margin-inline: auto; }
[data-design="b"] .pl-board__intro { margin-inline: auto; }
[data-design="b"] .pl-materials__title { margin-inline: auto; }
[data-design="b"] .pl-materials__items { margin-inline: auto; }
[data-design="b"] .pl-about__title { margin-inline: auto; }
[data-design="b"] .pl-about__block { margin-inline: 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; }
